/* ===== RESET & BASE ===== */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif; color: #1e293b; line-height: 1.7; background: #fff; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }
img { max-width: 100%; display: block; }
.container { max-width: 1100px; margin: 0 auto; padding: 0 24px; }

/* ===== SECTION HELPERS ===== */
.section { padding: 120px 0; }
.section--gray { background: #fff; border-top: 1px solid #e2e8f0; }
.section--dark { background: #0f172a; color: #fff; }
.section--blue { background: #fff; border-top: 1px solid #e2e8f0; }
.section--gradient { background: #fff; }
.section--photo { position: relative; background: #1e3a5f url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1200 600"><rect fill="%231e3a5f"/><polygon points="0,600 200,200 500,400 800,100 1200,300 1200,600" fill="%23264a6e" opacity=".5"/><polygon points="0,600 300,350 600,500 1000,250 1200,400 1200,600" fill="%231a3050" opacity=".6"/></svg>') center/cover; }
.section-title { font-family: 'DM Serif Display', Georgia, serif; font-size: 2.5rem; font-weight: 400; letter-spacing: -0.02em; margin-bottom: 16px; text-align: center; }
.section-title--white { color: #fff; }
.section-subtitle { text-align: center; color: #475569; font-size: 1.05rem; line-height: 1.7; letter-spacing: 0.01em; margin-bottom: 64px; max-width: 660px; margin-left: auto; margin-right: auto; }
.section-subtitle--white { color: rgba(255,255,255,.7); }
.label { display: block; text-transform: uppercase; font-size: 11px; letter-spacing: 3px; color: #0284c7; font-weight: 600; margin-bottom: 8px; }

/* ===== BUTTONS ===== */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; padding: 14px 36px; border-radius: 2px; font-size: 14px; font-weight: 600; font-family: inherit; cursor: pointer; transition: all .35s ease; border: 1.5px solid transparent; text-align: center; text-decoration: none; text-transform: uppercase; letter-spacing: 0.05em; }
.btn--primary { background: transparent; color: #0284c7; border-color: #0284c7; }
.btn--primary:hover { background: #0284c7; color: #fff; border-color: #0284c7; }
.btn--accent { background: #0ea5e9; color: #fff; border-color: #0ea5e9; }
.btn--accent:hover { background: #0284c7; border-color: #0284c7; }
.btn--outline-white { background: transparent; color: #fff; border-color: rgba(255,255,255,.35); }
.btn--outline-white:hover { background: #fff; color: #0f172a; border-color: #fff; }
.btn--outline { background: transparent; color: #1e293b; border-color: #cbd5e1; }
.btn--outline:hover { border-color: #0284c7; color: #0284c7; }
.btn--lg { padding: 18px 48px; font-size: 15px; }
.btn--sm { padding: 8px 20px; font-size: 12px; }
.btn--full { width: 100%; }
.badge { position: absolute; top: 16px; right: 16px; padding: 4px 12px; border-radius: 0; font-size: 10px; font-weight: 700; color: #fff; z-index: 2; letter-spacing: 0.5px; text-transform: uppercase; }
.badge--red { background: #0284c7; }
.badge--green { background: #0284c7; }

/* ===== TOP BAR ===== */
.top-bar { background: #0f172a; color: rgba(255,255,255,.7); font-size: 13px; padding: 8px 0; }
.top-bar__inner { display: flex; justify-content: space-between; align-items: center; }
.top-bar__left { display: flex; gap: 24px; flex-wrap: wrap; }
.top-bar__item { display: inline-flex; align-items: center; gap: 6px; color: rgba(255,255,255,.7); transition: color .2s; }
.top-bar__item:hover { color: #fff; }
.top-bar__socials { display: flex; gap: 8px; align-items: center; }
.top-bar__socials a { color: rgba(255,255,255,.4); transition: color .2s; }
.top-bar__socials a:hover { color: #fff; }
.tb-icon { display: flex; align-items: center; justify-content: center; width: 30px; height: 30px; border-radius: 50%; background: rgba(255,255,255,0.15); color: #fff !important; transition: background .2s; }
.tb-icon:hover { background: rgba(255,255,255,0.3) !important; }

/* ===== HEADER ===== */
.header { background: #fff; position: sticky; top: 0; z-index: 100; transition: box-shadow .3s; }
.header__inner { display: flex; align-items: center; justify-content: space-between; height: 72px; }
.header__logo { display: flex; align-items: center; gap: 10px; flex-shrink: 0; text-decoration: none; }
.header__logo-img { height: 48px; width: auto; object-fit: contain; }
.header__logo-text { font-size: 13px; font-weight: 700; color: #0f172a; line-height: 1.2; letter-spacing: 0.5px; text-transform: uppercase; }
.header__nav { display: flex; align-items: center; gap: 0; }
.nav-item > a { color: #334155; font-size: 14px; font-weight: 500; padding: 8px 10px; display: inline-flex; align-items: center; gap: 4px; transition: color .2s; border-radius: 6px; white-space: nowrap; }
.nav-item > a:hover { color: #0284c7; background: #f0f9ff; }
.header__right-group { display: flex; align-items: center; gap: 14px; flex-shrink: 0; }
.header__phone { display: inline-flex; align-items: center; gap: 6px; font-size: 14px; font-weight: 600; color: #0f172a; white-space: nowrap; transition: color .2s; }
.header__phone:hover { color: #0284c7; }
.header__messengers { display: flex; align-items: center; gap: 6px; }
.header__msg-icon { display: flex; align-items: center; justify-content: center; width: 32px; height: 32px; border-radius: 6px; color: #64748b; transition: all .2s; }
.header__msg-icon:hover { color: #0284c7; background: #f0f9ff; }
.header__akcioner { font-size: 14px; font-weight: 500; color: #334155; transition: color .2s; white-space: nowrap; }
.header__akcioner:hover { color: #0284c7; }
.header__cta { flex-shrink: 0; white-space: nowrap; }

/* Dropdown */
.has-dropdown { position: relative; }
.dropdown { display: none; position: absolute; top: 100%; left: 50%; transform: translateX(-50%); background: #fff; border-radius: 12px; box-shadow: 0 12px 40px rgba(0,0,0,.12); min-width: 240px; padding: 8px 0; padding-top: 16px; z-index: 200; border: 1px solid #e2e8f0; margin-top: 0; }
.dropdown::before { content: ''; position: absolute; top: 10px; left: 50%; transform: translateX(-50%) rotate(45deg); width: 12px; height: 12px; background: #fff; border-left: 1px solid #e2e8f0; border-top: 1px solid #e2e8f0; z-index: 1; }
.dropdown::after { content: ''; position: absolute; top: -12px; left: 0; right: 0; height: 12px; background: transparent; }
.dropdown > a { display: block; padding: 10px 20px; color: #334155; font-size: 14px; transition: all .15s; }
.dropdown > a:hover { background: #f0f9ff; color: #0284c7; }
.dropdown__divider { height: 1px; background: #e2e8f0; margin: 6px 12px; }
.dropdown__section-label { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .8px; color: #94a3b8; padding: 4px 20px 2px; }
.dropdown--cases { min-width: 300px; }
.dropdown--catalog { display: none; min-width: 560px; padding: 20px; left: 0; transform: none; flex-direction: row; gap: 0; }
.has-dropdown:hover .dropdown--catalog { display: flex; }
.catalog-col { flex: 1; padding: 0 16px; }
.catalog-col + .catalog-col { border-left: 1px solid #e2e8f0; }
.catalog-col__title { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .8px; color: #94a3b8; margin-bottom: 10px; padding: 0 4px; }
.catalog-link { display: block; padding: 8px 4px; color: #334155; font-size: 14px; border-radius: 6px; transition: all .15s; }
.catalog-link:hover { color: #0284c7; background: #f0f9ff; padding-left: 8px; }
.catalog-link--project { display: flex; flex-direction: column; gap: 2px; padding: 10px 8px; border-radius: 8px; border: 1px solid transparent; margin-bottom: 4px; }
.catalog-link--project strong { font-size: 14px; color: #0f172a; }
.catalog-link--project span { font-size: 12px; color: #64748b; }
.catalog-link--project:hover { border-color: #bfdbfe; background: #f0f9ff; }
.has-dropdown:hover .dropdown { display: block; }
.has-dropdown:hover .dropdown--mega { display: flex; flex-wrap: wrap; }
.has-dropdown:hover .dropdown--services { display: block; }

/* Services dropdown */
.dropdown--services { min-width: 560px; padding: 16px; padding-top: 24px; left: 0; transform: none; }
.dropdown--services::before { left: 40px; transform: rotate(45deg); }
.dropdown--services::after { left: 0; right: auto; width: 200px; }
.dropdown__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 4px; }
.dropdown__link { display: flex; align-items: flex-start; gap: 12px; padding: 12px; border-radius: 8px; transition: background .15s; }
.dropdown__link:hover { background: #f0f9ff; }
.dropdown__icon { font-size: 20px; flex-shrink: 0; width: 36px; height: 36px; background: #f0f9ff; border: 1px solid #bfdbfe; border-radius: 8px; display: flex; align-items: center; justify-content: center; }
.dropdown__link strong { display: block; font-size: 14px; color: #0f172a; }
.dropdown__link span { font-size: 12px; color: #64748b; }

/* Mega menu */
.dropdown--mega { min-width: 680px; padding: 24px; padding-top: 32px; gap: 24px; transform: translateX(-40%); }
.dropdown--mega::before { left: 45%; }
.mega-col { flex: 1; }
.mega-col h4 { font-size: 11px; text-transform: uppercase; letter-spacing: 1.5px; color: #94a3b8; font-weight: 600; margin-bottom: 8px; padding: 0 12px; }
.mega-col a { display: block; padding: 8px 12px; font-size: 14px; color: #334155; border-radius: 6px; transition: all .15s; }
.mega-col a:hover { background: #f0f9ff; color: #0284c7; }
.mega-banner { width: 100%; background: #f0f9ff; border-radius: 8px; padding: 16px; margin-top: 8px; display: flex; align-items: center; justify-content: space-between; gap: 16px; border: 1px solid #bfdbfe; }
.mega-banner span { font-size: 13px; color: #0f172a; font-weight: 500; }

/* Burger */
.burger { display: none; background: none; border: none; cursor: pointer; width: 28px; height: 20px; position: relative; z-index: 101; }
.burger span { display: block; width: 100%; height: 2px; background: #0f172a; position: absolute; left: 0; transition: all .3s; }
.burger span:nth-child(1) { top: 0; }
.burger span:nth-child(2) { top: 9px; }
.burger span:nth-child(3) { top: 18px; }

/* Mobile Menu */
.mobile-menu { position: fixed; top: 0; right: -100%; width: 100%; height: 100vh; background: #fff; z-index: 1000; transition: right .3s ease; overflow-y: auto; display: flex; flex-direction: column; }
.mobile-menu.active { right: 0; }
.mobile-menu__head { display: flex; justify-content: space-between; align-items: center; padding: 16px 24px; border-bottom: 1px solid #e2e8f0; }
.mobile-logo { font-weight: 700; font-size: 17px; }
.mobile-menu__close { background: none; border: none; cursor: pointer; color: #64748b; }
.mobile-menu__nav { flex: 1; padding: 8px 24px; }
.mob-toggle { width: 100%; text-align: left; background: none; border: none; font-size: 16px; font-weight: 500; padding: 14px 0; border-bottom: 1px solid #f1f5f9; cursor: pointer; display: flex; justify-content: space-between; align-items: center; font-family: inherit; color: #0f172a; }
.mob-arrow { color: #94a3b8; font-size: 18px; transition: transform .3s; }
.mob-toggle.active .mob-arrow { transform: rotate(90deg); }
.mob-sub { display: none; padding: 4px 0 8px 0; }
.mob-sub.active { display: block; }
.mob-sub a { display: block; padding: 10px 16px; font-size: 15px; color: #475569; border-radius: 6px; }
.mob-sub a:hover { background: #f0f9ff; }
.mob-link { display: block; font-size: 16px; font-weight: 500; padding: 14px 0; border-bottom: 1px solid #f1f5f9; color: #0f172a; }
.mobile-menu__bottom { padding: 24px; border-top: 1px solid #e2e8f0; display: flex; flex-direction: column; gap: 12px; }
.mob-phone { font-size: 18px; font-weight: 600; color: #0284c7; }
.mob-messengers { display: flex; gap: 8px; }
.mob-msg { padding: 8px 16px; background: #f0f9ff; border-radius: 8px; font-size: 14px; font-weight: 500; color: #0284c7; }
.mob-email { font-size: 14px; color: #64748b; }
.mob-cta { text-align: center; }

/* ===== HERO ===== */
.hero { position: relative; min-height: 100vh; display: flex; align-items: center; background: #1e293b url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1400 800"><rect fill="%231a3050"/><polygon points="0,800 200,300 500,500 800,200 1100,350 1400,150 1400,800" fill="%23264a6e" opacity=".4"/><polygon points="0,800 300,450 600,600 900,300 1400,500 1400,800" fill="%231e3a5f" opacity=".5"/><polygon points="0,800 400,550 700,650 1000,450 1400,600 1400,800" fill="%23172e4a" opacity=".6"/></svg>') center/cover; padding: 120px 0 0; }
.hero__overlay { position: absolute; inset: 0; background: linear-gradient(to bottom, rgba(15,23,42,.65), rgba(15,23,42,.4)); }
.hero__inner { position: relative; z-index: 2; color: #fff; }
.hero__content { max-width: 620px; text-align: left; padding-bottom: 20px; }
.hero__badge { display: inline-block; padding: 8px 24px; border: 1px solid rgba(255,255,255,.25); border-radius: 0; font-size: 12px; color: rgba(255,255,255,.8); margin-bottom: 32px; backdrop-filter: blur(4px); background: rgba(255,255,255,.06); text-transform: uppercase; letter-spacing: 2px; }
.hero__title { font-family: 'DM Serif Display', Georgia, serif; font-size: 3.2rem; font-weight: 400; margin-bottom: 20px; line-height: 1.15; letter-spacing: -0.02em; }
.hero__subtitle { font-size: 1.05rem; color: rgba(255,255,255,.7); margin-bottom: 24px; line-height: 1.7; max-width: 520px; }
.hero__checks { display: flex; flex-direction: column; gap: 10px; margin-bottom: 32px; }
.hero__check { display: flex; align-items: flex-start; gap: 10px; font-size: 14px; color: rgba(255,255,255,.75); line-height: 1.5; }
.hero__check svg { flex-shrink: 0; margin-top: 3px; }
.hero__note { font-size: 13px; color: rgba(255,255,255,.45); margin-top: 12px; }
.hero__buttons { display: flex; gap: 14px; align-items: flex-start; flex-wrap: wrap; }
.hero__buttons .btn--lg { padding: 16px 28px; font-size: 13px; }
.hero__paths { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 20px; }
.hero__path { display: inline-flex; align-items: center; justify-content: center; padding: 10px 14px; border: 1px solid rgba(255,255,255,.18); background: rgba(255,255,255,.08); color: rgba(255,255,255,.86); font-size: 13px; border-radius: 999px; transition: all .3s ease; }
.hero__path:hover { background: rgba(255,255,255,.16); color: #fff; border-color: rgba(255,255,255,.35); }
.btn__sub { display: block; font-size: 11px; font-weight: 400; text-transform: none; letter-spacing: 0; opacity: .8; margin-top: 4px; }
.hero__stats { position: relative; z-index: 2; display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid rgba(255,255,255,.1); margin-top: 16px; }
.hero__stat { background: rgba(255,255,255,.04); border-right: 1px solid rgba(255,255,255,.08); padding: 22px 16px; text-align: center; }
.hero__stat:last-child { border-right: none; }
.hero__stat-num { display: block; font-family: 'DM Serif Display', Georgia, serif; font-size: 1.5rem; font-weight: 400; color: #0ea5e9; line-height: 1.1; margin-bottom: 4px; }
.hero__stat-label { font-size: 12px; color: rgba(255,255,255,.5); }

/* ===== TRUST BAR ===== */
.trust { position: relative; z-index: 10; margin-top: -40px; padding-bottom: 40px; }
.trust__card { background: #fff; border-radius: 2px; border-top: 2px solid #0284c7; box-shadow: 0 2px 20px rgba(0,0,0,.06); display: flex; align-items: center; padding: 40px 48px; }
.trust__item { flex: 1; text-align: center; }
.trust__icon { font-size: 24px; margin-bottom: 8px; }
.trust__number { font-family: 'DM Serif Display', Georgia, serif; font-size: 2.2rem; font-weight: 400; color: #0284c7; }
.trust__label { font-size: 13px; color: #475569; margin-top: 4px; line-height: 1.4; }
.trust__divider { width: 1px; height: 60px; background: #e2e8f0; flex-shrink: 0; }

/* ===== WHO (О КОМПАНИИ) ===== */
.who__grid { display: grid; grid-template-columns: 55fr 45fr; gap: 48px; align-items: center; }
.who__text h2 { font-family: 'DM Serif Display', Georgia, serif; font-size: 2.2rem; font-weight: 400; letter-spacing: -0.02em; margin-bottom: 20px; }
.who__text p { color: #475569; margin-bottom: 16px; font-size: 15px; line-height: 1.7; }
.who__features { display: flex; flex-direction: column; gap: 16px; margin-top: 24px; }
.feature { display: flex; gap: 16px; align-items: flex-start; padding: 16px 16px 16px 20px; background: transparent; border-radius: 0; border: none; border-left: 2px solid #0284c7; }
.feature__icon-wrap { display: none; }
.feature strong { display: block; font-size: 14px; color: #0f172a; margin-bottom: 2px; }
.feature span { font-size: 13px; color: #64748b; }
.who__image { position: relative; }
.who__photo { background: linear-gradient(135deg, #bfdbfe, #93c5fd); border-radius: 3px; height: 480px; display: flex; align-items: center; justify-content: center; color: #1e40af; font-weight: 500; font-size: 15px; }
.who__badge { position: absolute; bottom: -16px; left: 24px; background: #fff; padding: 14px 24px; border-radius: 2px; box-shadow: 0 2px 16px rgba(0,0,0,.08); }
.who__badge strong { display: block; font-size: 14px; }
.who__badge span { font-size: 12px; color: #64748b; }

/* ===== SERVICES ===== */
.services__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.service-card { background: #fff; border: 1px solid rgba(226,232,240,0.5); border-radius: 3px; padding: 40px; position: relative; transition: all .4s ease; box-shadow: 0 1px 3px rgba(0,0,0,0.04); }
.service-card:hover { box-shadow: 0 4px 20px rgba(2,132,199,0.08); border-color: #bfdbfe; }
.service-card__icon-wrap { display: none; }
.service-card h3 { font-size: 17px; font-weight: 700; margin-bottom: 8px; }
.service-card__price { font-size: 20px; font-weight: 700; color: #0284c7; margin-bottom: 12px; }
.service-card p { font-size: 14px; color: #475569; margin-bottom: 16px; line-height: 1.6; }
.service-card__time { display: block; font-size: 13px; color: #64748b; margin-bottom: 16px; }
.service-card .btn { width: 100%; }

/* ===== STRATEGIES ===== */
.strategies__slider { display: flex; flex-wrap: wrap; gap: 20px; justify-content: center; }
.strategies__slider .strategy-card { flex: 0 0 calc(33.333% - 14px); min-width: 260px; }
.strategy-card { border-radius: 3px; overflow: hidden; position: relative; }
.strategy-card__photo { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; color: rgba(255,255,255,.5); font-size: 13px; }
.strategy-card__bg { height: 120px; background: linear-gradient(135deg, rgba(255,255,255,.08), rgba(255,255,255,.03)); }
.strategy-card__body { padding: 28px; background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.1); border-top: none; border-radius: 0 0 3px 3px; }
.strategy-card__body h3 { font-size: 1.2rem; margin-bottom: 8px; }
.strategy-card__body p { font-size: 14px; color: rgba(255,255,255,.6); margin-bottom: 16px; line-height: 1.5; }
.strategy-card__meta { display: flex; flex-direction: column; gap: 4px; margin-bottom: 16px; padding-top: 16px; border-top: 1px solid rgba(255,255,255,.1); font-size: 13px; color: rgba(255,255,255,.5); }
.meta-label { color: rgba(255,255,255,.3); }
.strategies__cta { text-align: center; margin-top: 48px; }
.strategies__cta p { color: rgba(255,255,255,.7); margin-bottom: 16px; font-size: 16px; }
.strategies__cta small { display: block; margin-top: 12px; color: rgba(255,255,255,.4); font-size: 13px; }

/* ===== PROCESS (GRID) ===== */
.process__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 28px; }
.process__step { text-align: center; padding: 28px 20px; background: #fff; border: 1px solid rgba(226,232,240,0.5); border-radius: 3px; box-shadow: 0 1px 3px rgba(0,0,0,.04); }
.process__num { width: 48px; height: 48px; background: transparent; color: #0284c7; border: 2px solid #0284c7; border-radius: 2px; display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 18px; margin: 0 auto 16px; }
.process__step h3 { font-size: 16px; font-weight: 700; margin-bottom: 8px; }
.process__step p { font-size: 14px; color: #475569; line-height: 1.6; }

/* ===== CATALOG ===== */
.catalog__tabs { display: flex; gap: 8px; justify-content: center; margin-bottom: 32px; flex-wrap: wrap; }
.tab { padding: 10px 24px; border-radius: 2px; font-size: 13px; font-weight: 500; cursor: pointer; border: 1px solid #cbd5e1; background: #fff; color: #475569; font-family: inherit; transition: all .35s ease; text-transform: uppercase; letter-spacing: 0.04em; }
.tab--active { background: #0284c7; color: #fff; border-color: #0284c7; }
.tab:hover:not(.tab--active) { border-color: #0284c7; color: #0284c7; }
.catalog__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.obj-card { background: #fff; border-radius: 3px; overflow: hidden; border: 1px solid rgba(226,232,240,0.5); transition: all .4s ease; box-shadow: 0 1px 3px rgba(0,0,0,.04); }
.obj-card:hover { box-shadow: 0 4px 20px rgba(2,132,199,0.08); border-color: #bfdbfe; }
.obj-card__img { height: 220px; background: linear-gradient(135deg, #bfdbfe, #7dd3fc); display: flex; align-items: center; justify-content: center; color: #1e40af; font-size: 14px; font-weight: 500; position: relative; }
.obj-card__badge { position: absolute; top: 12px; left: 12px; background: #0f172a; color: #fff; padding: 4px 12px; border-radius: 0; font-size: 10px; font-weight: 700; letter-spacing: 0.5px; text-transform: uppercase; }
.obj-card__body { padding: 20px; }
.obj-card__location { font-size: 14px; font-weight: 600; margin-bottom: 6px; }
.obj-card__details { font-size: 13px; color: #64748b; margin-bottom: 12px; }
.obj-card__price { font-size: 20px; font-weight: 700; color: #0f172a; margin-bottom: 8px; }
.obj-card__link { font-size: 14px; color: #0284c7; font-weight: 600; }
.catalog__actions { text-align: center; margin-top: 40px; }
.catalog__alt-link { display: block; margin-top: 16px; color: #0284c7; font-size: 14px; }

/* ===== CASES ===== */
.cases__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.case-card { background: #fff; border: 1px solid rgba(226,232,240,0.5); border-radius: 3px; overflow: hidden; position: relative; transition: all .4s ease; box-shadow: 0 1px 3px rgba(0,0,0,.04); }
.case-card:hover { box-shadow: 0 4px 20px rgba(2,132,199,0.08); border-color: #bfdbfe; }
.case-card__cover { height: 80px; background: linear-gradient(135deg, #bfdbfe, #7dd3fc); display: flex; align-items: center; justify-content: center; color: #1e40af; font-size: 11px; font-weight: 500; }
.case-card__top-bar { height: 2px; background: #0284c7; border-radius: 0; }
.case-card__strategy { display: inline-block; padding: 3px 8px; background: #f0f9ff; color: #0284c7; border-radius: 2px; font-size: 10px; font-weight: 600; margin: 12px 14px 4px; text-transform: uppercase; letter-spacing: 0.5px; }
.case-card__result { font-family: 'DM Serif Display', Georgia, serif; font-size: 1.8rem; font-weight: 400; color: #10b981; margin: 0 14px 8px; }
.case-card__profile { display: flex; align-items: center; gap: 8px; margin: 0 14px 6px; }
.case-card__avatar { width: 32px; height: 32px; background: #f0f9ff; border: 2px solid #bfdbfe; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-weight: 700; color: #0284c7; font-size: 10px; overflow: hidden; flex-shrink: 0; }
.case-card__name { font-weight: 600; font-size: 13px; }
.case-card__text { font-size: 12px; color: #475569; line-height: 1.5; margin: 0 14px 8px; }
.case-card__link { font-size: 12px; color: #0284c7; font-weight: 600; display: block; margin: 0 14px 14px; }
.cases__cta { text-align: center; margin-top: 40px; }

/* ===== LEGAL (ЮР ПРОВЕРКА) ===== */
.legal__grid { display: grid; grid-template-columns: 60fr 40fr; gap: 48px; align-items: flex-start; }
.legal__text h2 { font-family: 'DM Serif Display', Georgia, serif; font-size: 2.2rem; font-weight: 400; letter-spacing: -0.02em; margin-bottom: 24px; text-align: left; }
.legal__quote { font-family: 'DM Serif Display', Georgia, serif; font-size: 1.2rem; font-style: normal; font-weight: 400; border-left: 2px solid #0284c7; padding-left: 24px; margin: 28px 0; color: #0f172a; line-height: 1.6; }
.legal__risks { margin: 20px 0; }
.legal__risks li { padding: 6px 0; font-size: 14px; color: #475569; }
.legal__benefits { margin: 20px 0; }
.legal__benefits li { padding: 6px 0; font-size: 14px; color: #0f172a; }
.legal__text h3 { font-size: 16px; margin: 20px 0 8px; }
.tariff-card { background: #fff; border: 1px solid rgba(226,232,240,0.5); border-radius: 3px; padding: 36px; box-shadow: 0 1px 3px rgba(0,0,0,.04); }
.tariff-card h3 { text-align: center; font-size: 18px; margin-bottom: 24px; }
.tariff { display: flex; align-items: flex-start; gap: 12px; padding: 16px; border: 1.5px solid #e2e8f0; border-radius: 2px; margin-bottom: 12px; cursor: pointer; transition: border-color .35s ease; position: relative; }
.tariff:hover { border-color: #0284c7; }
.tariff input { margin-top: 4px; accent-color: #0284c7; }
.tariff__inner strong { display: block; font-size: 15px; margin-bottom: 2px; }
.tariff__inner span { font-size: 13px; color: #64748b; }
.tariff--rec { border-color: #0284c7; background: #f8fafc; }
.tariff__badge { position: absolute; top: -10px; right: 12px; background: #0284c7; color: #fff; padding: 2px 10px; border-radius: 0; font-size: 10px; font-weight: 700; letter-spacing: 0.5px; }
.tariff-card .btn { margin-top: 16px; }
.tariff-card__phone { text-align: center; margin-top: 16px; font-size: 14px; color: #64748b; }

/* ===== TOURS ===== */
.tours__overlay { position: absolute; inset: 0; background: rgba(15,23,42,.6); }
.tours__content { position: relative; z-index: 2; }
.tours__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-bottom: 32px; }
.tour-card { background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.12); border-radius: 3px; overflow: hidden; backdrop-filter: blur(4px); transition: all .4s ease; }
.tour-card:hover { background: rgba(255,255,255,.18); }
.tour-card__img { height: 120px; background: linear-gradient(135deg, rgba(255,255,255,.15), rgba(255,255,255,.05)); display: flex; align-items: center; justify-content: center; color: rgba(255,255,255,.4); font-size: 13px; }
.tour-card h3 { font-size: 1rem; font-weight: 700; margin-bottom: 4px; color: #fff; padding: 16px 20px 0; }
.tour-card__days { font-size: 12px; color: rgba(255,255,255,.5); font-weight: 500; padding: 0 20px; }
.tour-card p { font-size: 13px; color: rgba(255,255,255,.6); margin-top: 8px; line-height: 1.5; padding: 0 20px 20px; }
.tours__cta { text-align: center; }
.tours__alt { display: block; margin-top: 16px; color: rgba(255,255,255,.6); font-size: 14px; }
.tours__alt:hover { color: #fff; }

/* ===== ARTICLES ===== */
.articles__tabs { display: flex; gap: 8px; justify-content: center; margin-bottom: 32px; }
.articles__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.article-card { background: #fff; border-radius: 3px; overflow: hidden; border: 1px solid rgba(226,232,240,0.5); transition: all .4s ease; box-shadow: 0 1px 3px rgba(0,0,0,.04); }
.article-card:hover { box-shadow: 0 4px 20px rgba(2,132,199,0.08); border-color: #bfdbfe; }
.article-card__img { height: 160px; background: linear-gradient(135deg, #e0f2fe, #bfdbfe); display: flex; align-items: center; justify-content: center; color: #1e40af; font-size: 14px; }
.article-card__body { padding: 20px; }
.article-card__cat { font-size: 11px; text-transform: uppercase; color: #0284c7; font-weight: 600; letter-spacing: 1px; }
.article-card__body h3 { font-size: 15px; font-weight: 600; margin: 8px 0 8px; line-height: 1.4; }
.article-card__date { font-size: 12px; color: #94a3b8; margin-bottom: 8px; display: block; }
.article-card__body a { font-size: 14px; color: #0284c7; font-weight: 600; }
.articles__cta { text-align: center; margin-top: 40px; }
.articles__alt { display: block; margin-top: 16px; color: #0284c7; font-size: 14px; }

/* ===== REVIEWS ===== */
.reviews__ratings { display: flex; gap: 16px; justify-content: center; margin-bottom: 40px; flex-wrap: wrap; }
.reviews__badge { padding: 8px 20px; background: #fff; border: 1px solid #cbd5e1; border-radius: 2px; font-size: 12px; font-weight: 500; letter-spacing: 0.02em; }
.reviews__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.review-card { background: #fff; border: 1px solid rgba(226,232,240,0.5); border-radius: 3px; padding: 36px; box-shadow: 0 1px 3px rgba(0,0,0,.04); }
.review-card p { font-family: 'DM Serif Display', Georgia, serif; font-size: 1.05rem; color: #334155; line-height: 1.7; margin-bottom: 16px; font-style: normal; font-weight: 400; }
.review-card__stars { color: #f59e0b; font-size: 16px; margin-bottom: 12px; }
.review-card strong { display: block; font-size: 14px; }
.review-card span { font-size: 12px; color: #94a3b8; }
.reviews__cta { text-align: center; margin-top: 40px; }

/* ===== FAQ ===== */
.faq__grid { display: grid; grid-template-columns: 280px 1fr; gap: 48px; }
.faq__left h2 { font-size: 1.8rem; margin-bottom: 12px; text-align: left; }
.faq__left p { font-size: 14px; color: #475569; margin-bottom: 20px; line-height: 1.6; }
.faq__buttons { display: flex; gap: 8px; flex-wrap: wrap; }
.accordion__item { border-bottom: 1px solid #e2e8f0; }
.accordion__btn { width: 100%; text-align: left; background: none; border: none; font-size: 15px; font-weight: 600; padding: 18px 0; cursor: pointer; display: flex; justify-content: space-between; align-items: center; font-family: inherit; color: #0f172a; gap: 16px; }
.accordion__arrow { font-size: 20px; color: #94a3b8; transition: transform .3s; flex-shrink: 0; }
.accordion__btn.active .accordion__arrow { transform: rotate(90deg); color: #0284c7; }
.accordion__body { max-height: 0; overflow: hidden; transition: max-height .3s ease; }
.accordion__body p { padding: 0 0 18px; font-size: 14px; color: #475569; line-height: 1.7; }

/* ===== CTA FORM ===== */
.cta-section { position: relative; background: #0f172a; overflow: hidden; }
.cta-section__overlay { position: absolute; inset: 0; background: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1200 600"><polygon points="0,600 300,200 700,400 1200,100 1200,600" fill="rgba(0,0,0,.1)"/></svg>') center/cover; }
.cta-section__inner { position: relative; z-index: 2; display: grid; grid-template-columns: 1fr 420px; gap: 48px; align-items: center; }
.cta-section__text { color: #fff; }
.cta-section__text h2 { font-family: 'DM Serif Display', Georgia, serif; font-size: 2.2rem; font-weight: 400; letter-spacing: -0.02em; margin-bottom: 20px; }
.cta-section__price { margin-bottom: 16px; color: rgba(255,255,255,.85); }
.cta-section__text ul { margin: 16px 0; }
.cta-section__text li { padding: 4px 0; font-size: 15px; }
.cta-section__text li::before { content: "• "; }
.cta-section__note { margin-top: 12px; color: rgba(255,255,255,.7); font-size: 14px; }
.cta-section__proof { margin-top: 20px; font-weight: 600; font-size: 15px; }
.cta-section__form-wrap { }
.lead-form { background: #fff; border-radius: 3px; padding: 40px; display: flex; flex-direction: column; gap: 16px; box-shadow: 0 16px 48px rgba(0,0,0,.3); }
.lead-form input, .lead-form select { width: 100%; height: 48px; border: 1px solid #e2e8f0; border-radius: 2px; padding: 0 16px; font-size: 15px; font-family: inherit; color: #0f172a; transition: border-color .35s ease; }
.lead-form input:focus, .lead-form select:focus { outline: none; border-color: #0284c7; box-shadow: 0 0 0 3px rgba(2,132,199,.15); }
.lead-form small { font-size: 11px; color: #94a3b8; text-align: center; }
.lead-form small a { color: #0284c7; text-decoration: underline; }
.form-consents { display: flex; flex-direction: column; gap: 12px; margin-bottom: 4px; }
.consent-label { display: flex; align-items: flex-start; gap: 10px; font-size: 12px; color: #374151; line-height: 1.5; cursor: pointer; }
.consent-label input[type="checkbox"] { margin-top: 2px; flex-shrink: 0; accent-color: #0284c7; width: 18px; height: 18px; border-radius: 4px; cursor: pointer; }
.consent-label a { color: #0284c7; text-decoration: underline; }

/* ===== FOOTER ===== */
.footer { background: #0f172a; color: rgba(255,255,255,.7); padding: 80px 0 0; }
.footer__grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 56px; }
.footer__col--brand { }
.footer__logo-text { font-size: 18px; font-weight: 700; color: #fff; margin-bottom: 12px; }
.footer__col--brand > p { font-size: 14px; margin-bottom: 12px; }
.footer__legal { font-size: 12px; color: rgba(255,255,255,.35); line-height: 1.7; }
.footer__col h4 { color: rgba(255,255,255,.4); font-size: 12px; text-transform: uppercase; letter-spacing: 1.5px; margin-bottom: 16px; }
.footer__col a { display: block; font-size: 14px; padding: 4px 0; color: rgba(255,255,255,.6); transition: color .2s; }
.footer__col a:hover { color: #fff; }
.footer__contact { font-size: 14px; margin-bottom: 4px; }
.footer__messengers, .footer__socials { display: flex; gap: 8px; margin: 12px 0; }
.footer__messengers a, .footer__socials a { padding: 6px 14px; background: rgba(255,255,255,.08); border-radius: 6px; font-size: 12px; color: rgba(255,255,255,.6); }
.footer__messengers a:hover, .footer__socials a:hover { background: rgba(255,255,255,.15); color: #fff; }
.footer__address { font-size: 13px; color: rgba(255,255,255,.35); margin-top: 8px; }
.footer__bottom { border-top: 1px solid rgba(255,255,255,.1); margin-top: 40px; padding: 20px 0; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 16px; }
.footer__bottom span { font-size: 13px; color: rgba(255,255,255,.3); }
.footer__links { display: flex; gap: 20px; flex-wrap: wrap; }
.footer__links a { font-size: 12px; color: rgba(255,255,255,.3); }
.footer__links a:hover { color: rgba(255,255,255,.6); }

/* ===== FLOATING BUTTON ===== */
.floating-btn { position: fixed; bottom: 28px; right: 28px; width: 56px; height: 56px; border-radius: 2px; background: #0284c7; display: flex; align-items: center; justify-content: center; box-shadow: 0 4px 16px rgba(2,132,199,.3); z-index: 99; transition: all .35s ease; }
.floating-btn:hover { background: #0369a1; box-shadow: 0 6px 24px rgba(2,132,199,.4); }

/* ===== RESPONSIVE ===== */
@media (max-width: 1024px) {
  .header__nav, .header__right-group { display: none; }
  .burger { display: block; }
  .hero__inner { flex-direction: column; }
  .hero__stats { width: 100%; grid-template-columns: repeat(4, 1fr); margin-top: 24px; }
  .hero__title { font-size: 2.2rem; }
  .trust__card { flex-wrap: wrap; gap: 24px; padding: 24px; }
  .trust__divider { display: none; }
  .trust__item { flex: 1 1 45%; }
  .who__grid { grid-template-columns: 1fr; }
  .services__grid { grid-template-columns: repeat(2, 1fr); }
  .strategies__slider .strategy-card { flex: 0 0 calc(50% - 10px); min-width: 0; }
  .process__grid { grid-template-columns: repeat(2, 1fr); }
  .catalog__grid { grid-template-columns: repeat(2, 1fr); }
  .cases__grid { grid-template-columns: repeat(2, 1fr); }
  .legal__grid { grid-template-columns: 1fr; }
  .tours__grid { grid-template-columns: repeat(2, 1fr); }
  .articles__grid { grid-template-columns: repeat(2, 1fr); }
  .reviews__grid { grid-template-columns: repeat(2, 1fr); }
  .faq__grid { grid-template-columns: 1fr; }
  .cta-section__inner { grid-template-columns: 1fr; }
  .cta-section__form-wrap { max-width: 480px; }
  .footer__grid { grid-template-columns: repeat(2, 1fr); }
  .nav-overview__grid { grid-template-columns: repeat(3, 1fr); }
  .audiences__grid { grid-template-columns: 1fr; }
  .packages__grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 640px) {
  .top-bar { display: none; }
  .container { padding: 0 16px; }
  .section { padding: 80px 0; }
  .section-title { font-size: 1.5rem; }
  .hero { min-height: auto; padding: 100px 0 40px; }
  .hero__title { font-size: 1.8rem; }
  .hero__subtitle { font-size: .95rem; }
  .hero__checks { gap: 8px; margin-bottom: 24px; }
  .hero__check { font-size: 13px; }
  .hero__buttons { flex-direction: column; align-items: stretch; }
  .hero__buttons .btn--lg { padding: 14px 20px; font-size: 13px; }
  .hero__paths { flex-direction: column; align-items: stretch; }
  .hero__path { width: 100%; }
  .hero__stats { grid-template-columns: 1fr 1fr; }
  .hero__stat-num { font-size: 1.3rem; }
  .trust__item { flex: 1 1 100%; }
  .trust__number { font-size: 1.5rem; }
  .services__grid { grid-template-columns: 1fr; }
  .strategies__slider .strategy-card { flex: 0 0 100%; }
  .process__grid { grid-template-columns: 1fr; }
  .catalog__grid { grid-template-columns: 1fr; }
  .catalog__tabs { gap: 4px; }
  .tab { padding: 6px 12px; font-size: 12px; }
  .cases__grid { grid-template-columns: 1fr; }
  .case-card__result { font-size: 2rem; }
  .tours__grid { grid-template-columns: 1fr; }
  .articles__grid { grid-template-columns: 1fr; }
  .articles__tabs { gap: 4px; }
  .reviews__grid { grid-template-columns: 1fr; }
  .nav-overview__grid { grid-template-columns: 1fr; }
  .audience-card { padding: 28px 22px; }
  .packages__grid { grid-template-columns: 1fr; }
  .footer__grid { grid-template-columns: 1fr; }
  .footer__bottom { flex-direction: column; text-align: center; }
}

/* ===== POPUP / MODAL ===== */
.popup-overlay { display: none; position: fixed; inset: 0; background: rgba(0,0,0,.55); z-index: 2000; align-items: center; justify-content: center; }
.popup-overlay.active { display: flex; }
.popup { background: #fff; border-radius: 3px; padding: 44px 48px; max-width: 560px; width: 94%; position: relative; box-shadow: 0 24px 64px rgba(0,0,0,.3); animation: popupIn .3s ease; }
@keyframes popupIn { from { transform: scale(.9); opacity: 0; } to { transform: scale(1); opacity: 1; } }
.popup__close { position: absolute; top: 14px; right: 14px; background: none; border: none; font-size: 28px; color: #94a3b8; cursor: pointer; line-height: 1; width: 36px; height: 36px; display: flex; align-items: center; justify-content: center; border-radius: 8px; transition: all .2s; }
.popup__close:hover { color: #0f172a; background: #f1f5f9; }
.popup__title { font-size: 1.3rem; font-weight: 700; margin-bottom: 8px; color: #0f172a; }
.popup__subtitle { font-size: 14px; color: #64748b; margin-bottom: 20px; line-height: 1.5; }
.popup__form { display: flex; flex-direction: column; gap: 12px; }
.popup__form input, .popup__form select { width: 100%; height: 48px; border: 1px solid #e2e8f0; border-radius: 2px; padding: 0 16px; font-size: 15px; font-family: inherit; color: #0f172a; transition: border-color .35s ease; }
.popup__form input:focus, .popup__form select:focus { outline: none; border-color: #0284c7; box-shadow: 0 0 0 3px rgba(2,132,199,.15); }
.popup__privacy { display: block; margin-top: 12px; font-size: 11px; color: #94a3b8; text-align: center; }
.popup__privacy a { color: #0284c7; text-decoration: underline; }

/* ===== SCROLL REVEAL ===== */
.reveal { opacity: 0; transform: translateY(30px); transition: opacity .8s ease, transform .8s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }

/* ===== NAV OVERVIEW ===== */
.nav-overview__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.nav-overview__card { text-align: center; padding: 40px 32px; border: 1px solid rgba(226,232,240,0.5); border-radius: 3px; box-shadow: 0 1px 3px rgba(0,0,0,.04); transition: all .4s ease; }
.nav-overview__card:hover { box-shadow: 0 4px 20px rgba(2,132,199,0.08); border-color: #bfdbfe; }
.nav-overview__icon { margin-bottom: 20px; }
.nav-overview__card h3 { font-family: 'DM Serif Display', Georgia, serif; font-size: 1.3rem; font-weight: 400; margin-bottom: 12px; }
.nav-overview__card p { font-size: 14px; color: #475569; line-height: 1.6; margin-bottom: 24px; }

/* ===== AUDIENCE SPLIT ===== */
.audiences__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 28px; }
.audience-card { background: #fff; border: 1px solid rgba(226,232,240,0.7); border-radius: 3px; padding: 36px; box-shadow: 0 1px 3px rgba(0,0,0,.04); transition: all .35s ease; }
.audience-card:hover { box-shadow: 0 8px 28px rgba(2,132,199,.08); border-color: #bfdbfe; }
.audience-card h3 { font-family: 'DM Serif Display', Georgia, serif; font-size: 1.6rem; font-weight: 400; margin-bottom: 12px; color: #0f172a; }
.audience-card p { font-size: 15px; color: #475569; line-height: 1.7; margin-bottom: 18px; }
.audience-card__list { display: flex; flex-direction: column; gap: 10px; margin-bottom: 24px; }
.audience-card__list li { position: relative; padding-left: 18px; color: #334155; font-size: 14px; line-height: 1.6; }
.audience-card__list li::before { content: ""; position: absolute; left: 0; top: 9px; width: 6px; height: 6px; border-radius: 50%; background: #0284c7; }
.audience-card__actions { display: flex; gap: 10px; flex-wrap: wrap; }

/* ===== INVEST PACKAGES ===== */
.packages__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.package-card { background: #fff; border: 1px solid rgba(226,232,240,0.5); border-radius: 3px; padding: 36px 28px; position: relative; transition: all .4s ease; box-shadow: 0 1px 3px rgba(0,0,0,.04); display: flex; flex-direction: column; }
.package-card:hover { box-shadow: 0 4px 20px rgba(2,132,199,0.08); border-color: #bfdbfe; }
.package-card--featured { border-color: #0284c7; border-width: 2px; }
.package-card--premium { background: #0f172a; color: #fff; border-color: #0f172a; }
.package-card--premium .package-card__price { color: #0ea5e9; }
.package-card--premium .package-card__desc { color: rgba(255,255,255,.6); }
.package-card--premium .package-card__features li { color: rgba(255,255,255,.7); border-color: rgba(255,255,255,.08); }
.package-card--premium .package-card__capital { color: rgba(255,255,255,.5); }
.package-card__label { display: inline-block; font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 1.5px; color: #0284c7; margin-bottom: 8px; }
.package-card--premium .package-card__label { color: #0ea5e9; }
.package-card__name { font-family: 'DM Serif Display', Georgia, serif; font-size: 1.4rem; font-weight: 400; margin-bottom: 8px; }
.package-card__price { font-size: 1.5rem; font-weight: 700; color: #0284c7; margin-bottom: 4px; }
.package-card__capital { font-size: 13px; color: #64748b; margin-bottom: 16px; }
.package-card__desc { font-size: 14px; color: #475569; line-height: 1.6; margin-bottom: 20px; }
.package-card__features { list-style: none; margin-bottom: 24px; flex: 1; }
.package-card__features li { padding: 8px 0; font-size: 13px; border-bottom: 1px solid #f1f5f9; display: flex; align-items: flex-start; gap: 8px; }
.package-card__features li::before { content: "✓"; color: #0284c7; font-weight: 700; flex-shrink: 0; }
.package-card--premium .package-card__features li::before { color: #0ea5e9; }
.package-card .btn { width: 100%; margin-top: auto; }
.packages__cta { text-align: center; margin-top: 48px; }
.packages__cta p { color: #475569; margin-bottom: 16px; font-size: 16px; }

/* ===== PREMIUM SECTION DIVIDERS ===== */
.section + .section:not(.section--dark):not(.section--photo) { border-top: 1px solid #e2e8f0; }
