
:root{
  --bg:#0b0f1a;
  --surface:#0f172a;
  --card:#111827;
  --muted:#9aa4b2;
  --brand:#10b981;
  --brand2:#0ea5e9;
  --text:#f3f4f6;
  --accent:#f59e0b;
  --line:#1f2937;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,'Noto Sans',sans-serif;overflow-x:hidden;width:100%;max-width:100%}
body{position:relative}
img,video,iframe{max-width:100%;height:auto}
a{color:var(--brand2);text-decoration:none}a:hover{opacity:.9}
.container{max-width:1200px;margin:0 auto;padding:16px}
.nav{position:fixed!important;top:0!important;left:0!important;right:0!important;background:rgba(11,15,26,.95);backdrop-filter:saturate(180%) blur(8px);border-bottom:1px solid var(--line);z-index:1000!important;width:100%!important;margin:0;will-change:transform}
body{padding-top:0}
body > .container:first-of-type{padding-top:70px}
body > div:first-of-type:not(.nav):not(.container){padding-top:70px}
.nav .inner{display:flex;align-items:center;gap:12px;padding:10px 12px;position:relative;max-width:100%;box-sizing:border-box;width:100%;margin:0 auto}
.logo{display:flex;align-items:center;gap:10px;font-weight:800;letter-spacing:.3px;font-size:18px;flex-shrink:0;min-width:0}.logo .dot{width:10px;height:10px;border-radius:50%;background:var(--brand);flex-shrink:0}
.menu-toggle{display:none;background:none;border:none;color:var(--text);font-size:24px;cursor:pointer;padding:8px;margin-left:auto;flex-shrink:0;min-width:40px;width:40px;height:40px}
.navlinks{display:flex;flex-wrap:wrap;gap:10px;margin-left:auto;align-items:center;max-width:100%;overflow:hidden}
.btn{display:inline-block;background:var(--brand);color:#001b12;padding:10px 14px;border-radius:10px;font-weight:700;box-shadow:0 8px 24px rgba(16,185,129,.25);font-size:15px;white-space:nowrap;text-align:center;box-sizing:border-box}
.btn.secondary{background:var(--accent);color:#1f1300}
.iconbar{display:flex;gap:8px}.iconbar a{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--line);background:#0f172a;padding:8px 10px;border-radius:999px;color:var(--text);font-size:14px}
.nav-actions{display:none;gap:8px;align-items:center;flex-shrink:0}
.hero{display:grid;grid-template-columns:1.1fr .9fr;gap:24px;align-items:center;padding:32px 0}
.card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:16px;box-shadow:0 10px 30px rgba(0,0,0,.25)}
.grid{display:grid;gap:12px}.grid.cols-3{grid-template-columns:repeat(3,1fr)}.grid.cols-2{grid-template-columns:repeat(2,1fr)}
.badge{display:inline-flex;align-items:center;gap:8px;background:#0f172a;padding:8px 12px;border:1px solid var(--line);border-radius:999px;color:var(--muted);font-size:14px}
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.kpi{background:#0f172a;border:1px solid var(--line);border-radius:14px;padding:12px;text-align:center}.kpi strong{font-size:20px;color:var(--brand)}
.section{padding:32px 0}.h1{font-size:34px;line-height:1.15;margin:0 0 10px}.h2{font-size:26px;margin:0 0 10px}.h3{font-size:20px;margin:0 0 8px}.muted{color:var(--muted)}
.footer{border-top:1px solid var(--line);margin-top:32px}
.footer .cols{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:16px;padding:20px 0}.footer small{color:var(--muted)}
.footer .container{padding-left:16px;padding-right:16px}
.footer .list{list-style:none;padding:0;margin:0}.footer .list li{margin-bottom:8px}
.heroimg{aspect-ratio:1.1/1; background: radial-gradient(100% 100% at 30% 10%, #0b2239 0%, #071320 60%, #040a13 100%);border:1px solid var(--line);border-radius:16px; position:relative;overflow:hidden}

.table{width:100%;border-collapse:separate;border-spacing:0;background:#0f172a;border:1px solid var(--line);border-radius:12px;overflow:hidden}
.table th,.table td{padding:10px 12px;border-bottom:1px solid var(--line)}
.table th{background:#0b1528;text-align:left}
.table tr:last-child td{border-bottom:none}
.table tr:nth-child(odd) td{background:#0f192a}

.phone-blur{font-weight:800;letter-spacing:.4px}
.phone-blur .blur{filter:blur(7px);transition:filter .35s ease}
.phone-blur.reveal .blur{filter:blur(0)}

@media(min-width:1025px){ 
  .hide-desktop{display:none!important} 
  .show-desktop{display:inline-flex} 
  .menu-toggle{display:none!important}
  .nav-actions{display:none!important}
}
@media(max-width:1024px){
  .show-desktop{display:none!important} 
  .hide-desktop{display:inline-flex}
  .menu-toggle{display:block!important;font-size:24px;min-width:40px;width:40px;height:40px;flex-shrink:0;margin-left:auto}
  .nav-actions{display:flex}
  .nav .inner{flex-wrap:wrap;align-items:center;width:100%;max-width:100%;overflow:hidden;gap:8px;padding:10px 12px;box-sizing:border-box}
  .nav .inner > .logo{order:1;flex:1 1 auto;min-width:0;max-width:calc(100% - 60px);font-size:18px!important}
  .nav .inner > .menu-toggle{order:2;flex-shrink:0;margin-left:auto;font-size:24px!important;min-width:40px!important;width:40px!important;height:40px!important}
  .nav .inner > .nav-actions{order:3;width:100%;margin-top:0;display:flex;justify-content:space-between;gap:8px;flex-basis:100%}
  .navlinks{display:none;flex-direction:column;width:100%;order:4;margin-left:0;margin-top:0;padding-top:12px;border-top:1px solid var(--line);gap:12px;max-width:100%;overflow-x:hidden;box-sizing:border-box;flex-basis:100%}
  .nav.menu-open .navlinks{display:flex}
  .navlinks a{font-size:18px;padding:12px 0;width:100%;text-align:left;display:block;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;box-sizing:border-box}
  .iconbar{width:100%;justify-content:center;margin:8px 0;flex-wrap:wrap;max-width:100%;overflow:hidden;box-sizing:border-box}
  .iconbar a{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;box-sizing:border-box}
  .hero{grid-template-columns:1fr;padding:24px 0}
  .kpis{grid-template-columns:repeat(2,1fr)}
  .footer .cols{grid-template-columns:1fr}
  .grid.cols-3{grid-template-columns:1fr;gap:16px}
  .cities-in-section{grid-template-columns:1fr}
  .container{padding:12px;width:100%;max-width:100%;box-sizing:border-box}
  .footer .container{padding-left:20px!important;padding-right:20px!important}
  .footer .cols{padding:0!important}
  .section{padding:24px 0}
  body > .container:first-of-type{padding-top:90px!important}
  body > div:first-of-type:not(.nav):not(.container){padding-top:90px!important}
  .h1{font-size:32px;line-height:1.2;word-wrap:break-word}
  .h2{font-size:26px;word-wrap:break-word}
  .h3{font-size:20px;word-wrap:break-word;line-height:1.3}
  .card{padding:20px;width:100%}
  .card .h3{font-size:20px;line-height:1.3;margin-bottom:12px;word-wrap:break-word}
  .card .h3 a{font-size:20px;line-height:1.3}
  .card p{font-size:17px;line-height:1.6;word-wrap:break-word}
  .badge{font-size:16px;padding:10px 14px;word-wrap:break-word}
  .btn{font-size:17px;padding:12px 18px;width:auto;min-width:auto}
  .muted{font-size:17px;line-height:1.6}
  .logo{font-size:18px;flex-shrink:0;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .logo a{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}
  .nav-actions{width:100%;justify-content:space-between;margin-top:0;order:3;flex-wrap:nowrap;gap:8px;box-sizing:border-box}
  .nav-actions .btn{flex:1 1 0;min-width:0;max-width:none;padding:12px 8px;font-size:16px;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;box-sizing:border-box}
  .table{font-size:16px}
  .table th,.table td{padding:12px;font-size:16px}
  .cta{max-width:100%!important;overflow:hidden!important;box-sizing:border-box!important}
  .cta .btn{max-width:100%!important;overflow:hidden!important;text-overflow:ellipsis!important;white-space:nowrap!important;box-sizing:border-box!important}
}
@media(max-width:480px){
  .h1{font-size:28px;line-height:1.3}
  .h2{font-size:24px;line-height:1.3}
  .h3{font-size:19px;line-height:1.4}
  .card{padding:16px;width:100%}
  .card .h3{font-size:19px;line-height:1.4;margin-bottom:10px}
  .card .h3 a{font-size:19px;line-height:1.4}
  .card p{font-size:16px;line-height:1.7;margin-bottom:12px}
  .card a{font-size:18px}
  .badge{font-size:15px;padding:8px 12px}
  .btn{font-size:16px;padding:11px 16px;width:100%;max-width:100%}
  .navlinks a{font-size:18px;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .container{padding:10px;width:100%;max-width:100%;box-sizing:border-box}
  .footer .container{padding-left:20px!important;padding-right:20px!important}
  .footer .cols{padding:0!important}
  .section{padding:20px 0}
  body > .container:first-of-type{padding-top:90px!important}
  body > div:first-of-type:not(.nav):not(.container){padding-top:90px!important}
  .nav-actions{flex-direction:row;gap:8px;flex-wrap:nowrap;width:100%}
  .nav-actions .btn{flex:1 1 0;min-width:0;max-width:none;width:auto;padding:11px 8px;font-size:15px;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;box-sizing:border-box}
  .iconbar a{font-size:14px;padding:6px 8px;max-width:100%;overflow:hidden;text-overflow:ellipsis}
  .logo{font-size:17px;max-width:calc(100% - 50px);flex-shrink:0!important}
  .menu-toggle{font-size:22px;min-width:36px;width:36px;height:36px;top:10px;right:10px;flex-shrink:0!important}
  .nav .inner{padding:10px}
  .table{font-size:15px}
  .table th,.table td{padding:10px 8px;font-size:15px}
  .muted{font-size:16px}
  .cta{max-width:100%!important;overflow:hidden!important;box-sizing:border-box!important;flex-wrap:wrap!important}
  .cta .btn{max-width:calc(50% - 6px)!important;overflow:hidden!important;text-overflow:ellipsis!important;white-space:nowrap!important;box-sizing:border-box!important;flex:1 1 calc(50% - 6px)!important;min-width:0!important}
  
  /* Дополнительные отступы для футера на маленьких экранах */
  .footer {
    padding: 20px !important;
  }
  
  .footer .container {
    padding: 0 !important;
    margin: 0 !important;
  }
  
  .footer .cols {
    padding: 0 !important;
    gap: 18px;
    margin: 0 !important;
  }
  
  .footer .cols > div {
    padding: 0 !important;
    margin: 0 !important;
  }
  
  .footer .contact-item {
    margin-bottom: 12px;
  }
}

/* Контентные блоки */
.content-blocks {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
    margin: 20px 0;
}

.content-block {
    background: var(--card);
    border: 1px solid var(--line);
    padding: 20px;
    border-radius: 14px;
    transition: transform 0.3s, box-shadow 0.3s;
}

.content-block:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 24px rgba(16, 185, 129, 0.15);
}

.content-block h3 {
    color: var(--brand);
    margin: 0 0 12px 0;
    font-size: 18px;
    font-weight: 700;
}

.content-block p {
    color: var(--muted);
    margin: 0;
    font-size: 15px;
    line-height: 1.6;
}

/* Принудительные отступы для футера на мобильных - МАКСИМАЛЬНЫЙ ПРИОРИТЕТ */
@media (max-width: 1024px) {
    .footer * {
        padding-left: 0 !important;
        margin-left: 0 !important;
    }
    
    .footer .container {
        padding-left: 20px !important;
        padding-right: 20px !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
        box-sizing: border-box !important;
    }
    
    .footer .cols {
        padding-left: 0 !important;
        padding-right: 0 !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
    }
    
    .footer .cols > div {
        padding-left: 0 !important;
        margin-left: 0 !important;
    }
}

/* Улучшения футера для мобильных */
.footer .contact-item {
    margin-bottom: 15px;
}

.footer .contact-item strong {
    color: var(--text);
    font-size: 14px;
    font-weight: 600;
}

.footer .contact-item a {
    color: var(--brand);
    text-decoration: none;
}

.footer .contact-item a:hover {
    opacity: 0.8;
}

@media (max-width: 1024px) {
    .footer {
        padding: 30px 0 20px 0;
    }
    
    .footer .container {
        padding-left: 20px !important;
        padding-right: 20px !important;
    }
    
    .footer .cols {
        gap: 25px;
        padding: 0 !important;
    }
    
    .footer .cols > div {
        padding: 0;
    }
    
    .footer .h3 {
        font-size: 18px;
        margin-bottom: 15px;
        color: var(--text);
        font-weight: 600;
    }
    
    .footer .list li {
        margin-bottom: 12px;
    }
    
    .footer .list li a {
        font-size: 16px;
        line-height: 1.5;
        color: var(--muted);
        transition: color 0.2s ease;
    }
    
    .footer .list li a:hover {
        color: var(--brand);
    }
    
    .footer .iconbar {
        margin-top: 15px;
        gap: 10px;
        justify-content: flex-start;
    }
    
    .footer .iconbar a {
        font-size: 15px;
        padding: 8px 12px;
    }
    
    .footer p {
        font-size: 16px;
        line-height: 1.6;
        margin-bottom: 8px;
    }
    
    .footer .muted {
        font-size: 16px;
    }
    
    .footer .contact-item {
        margin-bottom: 18px;
    }
    
    .footer .contact-item strong {
        font-size: 15px;
        display: block;
        margin-bottom: 4px;
    }
}

@media (max-width: 768px) {
    .content-blocks {
        grid-template-columns: 1fr;
        gap: 12px;
    }
    
    .content-block {
        padding: 16px;
    }
    
    .content-block h3 {
        font-size: 17px;
    }
    
    .content-block p {
        font-size: 14px;
    }
    
    .footer {
        padding: 25px 20px 15px 20px !important;
    }
    
    .footer .container {
        padding-left: 0 !important;
        padding-right: 0 !important;
        margin: 0 !important;
    }
    
    .footer .cols {
        padding: 0 !important;
        gap: 20px;
        margin: 0 !important;
    }
    
    .footer .cols > div {
        padding: 0 !important;
        margin: 0 !important;
    }
    
    .footer .h3 {
        font-size: 17px;
        margin-bottom: 12px;
    }
    
    .footer .list li a {
        font-size: 15px;
    }
    
    .footer .iconbar a {
        font-size: 14px;
        padding: 6px 10px;
    }
    
    .footer p {
        font-size: 15px;
        margin-bottom: 6px;
    }
    
    .footer .muted {
        font-size: 15px;
    }
    
    .footer .contact-item {
        margin-bottom: 15px;
    }
    
    .footer .contact-item strong {
        font-size: 14px;
        margin-bottom: 3px;
    }
    
    .footer small {
        font-size: 13px;
        text-align: center;
        display: block;
        margin-top: 15px;
        padding-top: 15px;
        border-top: 1px solid var(--line);
    }
}

/* ===== БРАУЗЕРНАЯ ГЕОЛОКАЦИЯ ===== */

.geo-banner {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    background: linear-gradient(135deg, #10b981, #059669);
    color: white;
    z-index: 10000;
    box-shadow: 0 -4px 20px rgba(16, 185, 129, 0.3);
    transform: translateY(100%);
    transition: transform 0.3s ease-out;
}

.geo-banner-content {
    max-width: 1200px;
    margin: 0 auto;
    padding: 20px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    position: relative;
}

.geo-banner-header h3 {
    margin: 0 0 4px 0;
    font-size: 18px;
    font-weight: 600;
    color: white;
}

.geo-banner-header p {
    margin: 0;
    font-size: 14px;
    opacity: 0.9;
    color: white;
}

.geo-banner-actions {
    display: flex;
    gap: 12px;
    align-items: center;
    flex-shrink: 0;
}

.geo-banner .btn {
    padding: 10px 16px;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 500;
    border: none;
    cursor: pointer;
    transition: all 0.2s ease;
    display: flex;
    align-items: center;
    gap: 6px;
    white-space: nowrap;
}

.geo-banner .btn-primary {
    background: white;
    color: #10b981;
}

.geo-banner .btn-primary:hover {
    background: #f9fafb;
    transform: translateY(-1px);
}

.geo-banner .btn-secondary {
    background: rgba(255, 255, 255, 0.2);
    color: white;
    border: 1px solid rgba(255, 255, 255, 0.3);
}

.geo-banner .btn-secondary:hover {
    background: rgba(255, 255, 255, 0.3);
}

.geo-banner .btn-outline {
    background: transparent;
    color: white;
    border: 1px solid rgba(255, 255, 255, 0.5);
}

.geo-banner .btn-outline:hover {
    background: rgba(255, 255, 255, 0.1);
    border-color: white;
}

.geo-banner-close {
    position: absolute;
    top: 15px;
    right: 15px;
    background: none;
    border: none;
    color: white;
    font-size: 24px;
    font-weight: 300;
    cursor: pointer;
    padding: 0;
    width: 30px;
    height: 30px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    transition: all 0.2s ease;
    opacity: 0.7;
}

.geo-banner-close:hover {
    background: rgba(255, 255, 255, 0.2);
    opacity: 1;
    transform: scale(1.1);
}

/* Баннер загрузки */
.geo-banner-loading {
    background: linear-gradient(135deg, #6366f1, #4f46e5);
}

.geo-banner-loading .geo-banner-content {
    justify-content: center;
    padding: 24px;
}

.geo-loading-spinner {
    width: 24px;
    height: 24px;
    border: 3px solid rgba(255, 255, 255, 0.3);
    border-top: 3px solid white;
    border-radius: 50%;
    animation: spin 1s linear infinite;
    margin-right: 12px;
}

.geo-loading-text {
    font-size: 16px;
    font-weight: 500;
}

@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

/* Большой баннер для выбора из нескольких городов */
.geo-banner-large {
    background: white;
    color: var(--text);
    border-top: 1px solid var(--line);
    max-height: 60vh;
    overflow-y: auto;
}

.geo-banner-large .geo-banner-content {
    flex-direction: column;
    align-items: stretch;
    padding: 24px;
}

.geo-banner-large .geo-banner-header {
    text-align: center;
    margin-bottom: 20px;
}

.geo-banner-large .geo-banner-header h3 {
    color: var(--text);
    font-size: 20px;
    margin-bottom: 8px;
}

.geo-banner-large .geo-banner-header p {
    color: var(--muted);
    font-size: 16px;
}

.geo-cities-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin-bottom: 20px;
}

.geo-city-option {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px;
    background: var(--card);
    border: 1px solid var(--line);
    border-radius: 12px;
    transition: all 0.2s ease;
}

.geo-city-option:hover {
    border-color: var(--brand2);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(16,185,129,.1);
}

.geo-city-info {
    flex: 1;
}

.geo-city-name {
    font-size: 16px;
    font-weight: 600;
    color: var(--text);
    margin-bottom: 4px;
}

.geo-city-details {
    font-size: 14px;
    color: var(--muted);
    margin-bottom: 2px;
}

.geo-city-distance {
    font-size: 12px;
    color: var(--brand2);
    font-weight: 500;
}

.geo-banner-large .geo-banner-close {
    color: var(--muted);
    top: 20px;
    right: 20px;
}

.geo-banner-large .geo-banner-close:hover {
    background: var(--hover);
    color: var(--text);
}

/* Мобильная версия */
@media (max-width: 768px) {
    .geo-banner-content {
        flex-direction: column;
        gap: 16px;
        padding: 16px;
        text-align: center;
    }
    
    .geo-banner-actions {
        width: 100%;
        justify-content: center;
        flex-wrap: wrap;
    }
    
    .geo-banner .btn {
        flex: 1;
        min-width: 120px;
        justify-content: center;
    }
    
    .geo-banner-close {
        top: 10px;
        right: 10px;
    }
    
    .geo-city-option {
        flex-direction: column;
        align-items: stretch;
        gap: 12px;
        text-align: center;
    }
    
    .geo-city-option .btn {
        align-self: center;
        min-width: 100px;
    }
}

/* Адаптация для маленьких экранов */
@media (max-width: 480px) {
    .geo-banner-actions {
        flex-direction: column;
        width: 100%;
    }
    
    .geo-banner .btn {
        width: 100%;
        justify-content: center;
    }
    
    .geo-banner-header h3 {
        font-size: 16px;
    }
    
    .geo-banner-header p {
        font-size: 13px;
    }
}

/* Анимация появления */
.geo-banner.show {
    transform: translateY(0);
}

/* Отступ для контента когда показан баннер */
body.geo-banner-shown {
    padding-bottom: 120px;
}

@media (max-width: 768px) {
    body.geo-banner-shown {
        padding-bottom: 140px;
    }
}