@charset "UTF-8";
/*
Theme Name: Stat Theme
Theme URI: http://www.lnu.edu.ua/
Author: the LNU team
Author URI: http://www.lnu.edu.ua/
Description: Stat Theme
Version: 1.0
License: GNU General Public License v2 or later
License URI: LICENSE
Text Domain: Stat Theme
*/

/* =========================================================
   FONTS
   ========================================================= */

@font-face {
    font-family: 'GothaPro';
    src: url('fonts/GothamPro-Medium.eot');
    src: local('Gotham Pro Medium'), local('GothamPro-Medium'),
        url('fonts/GothamPro-Medium.eot?#iefix') format('embedded-opentype'),
        url('fonts/GothamPro-Medium.woff') format('woff'),
        url('fonts/GothamPro-Medium.ttf') format('truetype');
    font-weight: 500;
    font-style: normal;
}

@font-face {
    font-family: 'GothaPro';
    src: url('fonts/GothamPro-Bold.eot');
    src: local('Gotham Pro Bold'), local('GothamPro-Bold'),
        url('fonts/GothamPro-Bold.eot?#iefix') format('embedded-opentype'),
        url('fonts/GothamPro-Bold.woff') format('woff'),
        url('fonts/GothamPro-Bold.ttf') format('truetype');
    font-weight: bold;
    font-style: normal;
}

@font-face {
    font-family: 'GothaPro';
    src: url('fonts/GothamPro-Light.eot');
    src: local('Gotham Pro Light'), local('GothamPro-Light'),
        url('fonts/GothamPro-Light.eot?#iefix') format('embedded-opentype'),
        url('fonts/GothamPro-Light.woff') format('woff'),
        url('fonts/GothamPro-Light.ttf') format('truetype');
    font-weight: 300;
    font-style: normal;
}

@font-face {
    font-family: 'GothaPro';
    src: url('fonts/GothamPro.eot');
    src: local('Gotham Pro'), local('GothamPro'),
        url('fonts/GothamPro.eot?#iefix') format('embedded-opentype'),
        url('fonts/GothamPro.woff') format('woff'),
        url('fonts/GothamPro.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
}

/* =========================================================
   RESET / BASE
   ========================================================= */

* {
    border: 0;
    margin: 0;
    padding: 0;
    background: transparent no-repeat left top;
    word-wrap: break-word;
    outline: none;
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

body {
    font-size: 16px;
    line-height: 24px;
    font-style: normal;
    font-weight: 400;
    font-family: 'GothaPro', sans-serif;
    background-color: #fff;
    color: #3c3c3c;
}

img {
    max-width: 100%;
    height: auto;
    display: block;
}

a,
a:active,
a:focus {
    text-decoration: none;
    color: #3c3c3c;
}

a:hover {
    text-decoration: none;
    color: #0dd1b0;
}

h1 {
    font-size: 85px;
    line-height: 85px;
    margin-bottom: 30px;
    font-weight: bold;
}

h2 {
    font-size: 40px;
    line-height: 40px;
    margin-bottom: 20px;
    font-weight: 500;
}

h3 {
    font-size: 30px;
    line-height: 30px;
    margin-bottom: 20px;
    font-weight: 500;
}

h4 {
    font-size: 20px;
    line-height: 20px;
    margin-bottom: 20px;
    font-weight: bold;
}

p {
    margin-bottom: 12px;
}

section {
    position: relative;
}

.container {
    width: 100%;
    margin: 0 auto;
    padding-left: 15px;
    padding-right: 15px;
}

@media (min-width: 1200px) {
    .container {
        max-width: 1170px;
    }
}

/* =========================================================
   HEADER / MENU
   ========================================================= */

header {
    height: 100px;
    display: flex;
    align-items: center;
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 100;
    background: #fff;
    -webkit-box-shadow: 0 2px 17px 3px rgba(0, 0, 0, 0.1);
    -moz-box-shadow: 0 2px 17px 3px rgba(0, 0, 0, 0.1);
    box-shadow: 0 2px 17px 3px rgba(0, 0, 0, 0.1);
}

#top {
    margin-top: 100px;
}

.lang-box ul {
    display: flex;
    justify-content: flex-end;
    list-style: none;
    margin: 0;
    padding: 0;
}

.lang-box ul li {
    display: inline-block;
    margin-left: 10px;
}

.topnav-box {
    margin-top: 10px;
}

.topnav-box #menu-header {
    display: flex;
    justify-content: flex-end;
    list-style: none;
    margin: 0;
    padding: 0;
}

.topnav-box #menu-header > li {
    margin-left: 20px;
    display: block;
}

.topnav-box #menu-header > li a {
    font-size: 16px;
    font-weight: 500;
}

/* =========================================================
   LEGACY THEME BLOCKS
   ========================================================= */

.head-block {
    width: 100%;
    height: 860px;
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    display: flex;
    align-items: center;
}

.head-block h1 {
    color: #fff;
    position: relative;
    z-index: 2;
    margin-top: 130px;
    line-height: 105px;
}

.head-block .button-block {
    margin-top: 85px;
    margin-left: 113px;
}

.head-block .button-block .btn {
    padding: 11px 25px;
    border-width: 2px;
    border-radius: 10px;
}

.head-block .title-block {
    width: 100%;
    position: relative;
    height: 300px;
    padding: 35px 0 0 115px;
    display: flex;
    align-items: center;
    letter-spacing: 4px;
}

.head-block .title-block::before {
    content: '';
    width: 570px;
    height: 100%;
    display: block;
    position: absolute;
    left: 18px;
    top: 45px;
    background-color: rgba(13, 209, 176, 0.6);
    z-index: 1;
}

.about {
    font-size: 18px;
    line-height: 25px;
    background: #f6f6f6;
    padding: 50px 0;
}

.about p {
    margin-bottom: 10px;
}

.about h2 {
    text-transform: uppercase !important;
}

.about .blue-block {
    background: #4559ce !important;
    padding: 30px 30px !important;
    color: #fff !important;
}

.about .blue-block p {
    margin-bottom: 15px !important;
}

.about h3 {
    font-size: 30px !important;
}

.advantages {
    background-position: center 150px;
    background-repeat: no-repeat;
    padding: 80px 0;
    max-width: 100%;
    background-size: contain;
}

.advantages-images img {
    width: 100%;
    max-width: 100%;
}

#advantages h2 {
    text-align: center;
}

.et-db #et-boc .et_pb_row {
    max-width: 1170px !important;
}

#conditions {
    position: relative;
}

#conditions .container {
    background: #fff;
    position: relative;
    z-index: 2;
}

#conditions h2 {
    text-align: center !important;
    margin-bottom: 60px !important;
    font-size: 40px;
    text-transform: uppercase !important;
}

#conditions .blue-box {
    width: 12%;
    height: 270px;
    position: absolute;
    display: flex;
    justify-content: flex-end;
    align-items: center;
    padding-right: 30px;
    z-index: 1;
}

#annotation {
    margin: 30px 0;
}

#annotation .container {
    position: relative;
}

#annotation h2 {
    font-size: 40px;
    text-transform: uppercase;
}

#annotation .green-box {
    position: absolute;
    max-height: 600px;
    height: 100%;
    width: 30%;
    right: 0;
    z-index: -1;
    display: flex;
    justify-content: flex-end;
    align-items: center;
}

#annotation .green-box2 {
    position: absolute;
    left: 0;
    top: 50%;
    width: 150px;
    height: 160px;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    padding-left: 20px;
}

#annotation .blue-box {
    height: 160px;
    width: 200px;
    position: absolute;
    bottom: -60px;
    left: -120px;
    display: flex;
    justify-content: flex-end;
    align-items: center;
    padding-right: 30px;
}

#annotation .et_pb_accordion {
    padding: 70px;
    -webkit-box-shadow: 0 2px 17px 3px rgba(0, 0, 0, 0.1);
    -moz-box-shadow: 0 2px 17px 3px rgba(0, 0, 0, 0.1);
    box-shadow: 0 2px 17px 3px rgba(0, 0, 0, 0.1);
    background: #fff;
}

#annotation #et-boc .et_pb_toggle {
    border: 0 !important;
}

#annotation #et-boc .et_pb_toggle_open .et_pb_toggle_title,
#annotation #et-boc .et_pb_toggle_open h5.et_pb_toggle_title {
    display: block;
    padding: 20px 30px;
    font-size: 20px;
    text-transform: uppercase;
    color: #fff;
}

#annotation #et-boc .et_pb_toggle_open {
    padding: 10px 0;
}

#annotation #et-boc .et_pb_toggle_open p {
    padding: 0 30px;
}

#annotation #et-boc .et_pb_toggle_close {
    background: #fff;
}

#annotation #et-boc .et_pb_accordion .et_pb_toggle {
    margin-bottom: 0;
}

#annotation #et-boc .et_pb_section {
    padding: 0;
}

.grid-box {
    position: relative;
    margin-bottom: 20px !important;
}

.grid-box .et_pb_text_inner span {
    position: absolute;
    font-size: 60px;
    display: block !important;
    font-weight: 500;
}

.grid-box .et_pb_text_inner h3 {
    padding-left: 60px !important;
    font-weight: bold !important;
    font-size: 20px !important;
    text-transform: uppercase !important;
}

.grid-box .et_pb_text_inner div {
    padding-left: 60px !important;
}

#conditions .button-panel {
    text-align: center !important;
}

#conditions .button-panel .btn {
    padding: 11px 25px;
    border-width: 2px;
    border-radius: 10px;
    margin: 0 15px;
    min-width: 250px;
    font-size: 16px;
}

#conditions .button-panel .btn-outline-primary:hover,
#conditions .button-panel .btn-primary:hover {
    color: #ffffff;
}

#teachers {
    margin: 100px 0 0;
}

#teachers h2 {
    font-size: 40px;
    text-transform: uppercase;
}

#teachers #et-boc .et_pb_section {
    padding: 0;
}

#teachers .et_pb_team_member {
    max-height: 470px;
    width: 100%;
    margin-bottom: 50px !important;
}

#teachers .et_pb_team_member:after {
    clear: both;
    content: '';
    width: 100%;
    display: block;
}

#teachers .et_pb_team_member_image {
    overflow: hidden;
    z-index: -1;
}

#teachers .et_pb_team_member_description {
    position: relative;
}

#teachers .et_pb_team_member_description h4 {
    height: 75px;
    display: flex;
    position: absolute;
    width: 85%;
    margin: 0;
    padding: 0 0 0 20px;
    top: -120px;
    align-items: center;
    color: #fff;
    font-size: 20px;
    text-transform: uppercase;
}

#teachers .et_pb_team_member_description h4:before {
    position: absolute;
    content: '';
    width: 100%;
    height: 100%;
    left: 0;
    opacity: 0.7;
    z-index: -1;
    -webkit-transition: all 0.3s ease-out;
    -moz-transition: all 0.3s ease-out;
    -o-transition: all 0.3s ease-out;
    transition: all 0.3s ease-out;
}

#cooperation {
    margin: 100px 0;
}

#cooperation h2 {
    font-size: 40px;
    text-transform: uppercase;
    text-align: center;
    margin-bottom: 30px;
}

#cooperation #et-boc .et_pb_section {
    padding: 0;
}

#cooperation .et_pb_image {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
}

.youtube-box {
    height: 160px;
    width: 100%;
    display: flex;
    border-width: 2px;
    border-style: solid;
    font-size: 40px;
    text-transform: uppercase;
    justify-content: center;
    align-items: center;
    font-weight: 500;
    margin-bottom: 30px;
}

.youtube-box img {
    margin-right: 30px;
}

.site-footer {
    height: 100px;
    -webkit-box-shadow: 0 2px 17px 3px rgba(0, 0, 0, 0.1);
    -moz-box-shadow: 0 2px 17px 3px rgba(0, 0, 0, 0.1);
    box-shadow: 0 2px 17px 3px rgba(0, 0, 0, 0.1);
    background: #fff;
    margin-top: 30px;
    justify-content: center;
    align-items: center;
    display: flex;
}

.site-footer .text {
    font-size: 16px;
    color: #3c3c3c;
}

#contacts {
    margin: 100px 0 50px;
}

#contacts #et-boc .et_pb_section {
    padding: 0;
}

.contact-form-left {
    font-weight: normal;
    padding: 60px 55px !important;
    font-size: 20px;
    color: #fff !important;
    line-height: 32px;
}

.contact-form-left h3 {
    font-size: 30px !important;
}

.contact-form-right {
    -webkit-box-shadow: 0 2px 17px 3px rgba(0, 0, 0, 0.1) !important;
    -moz-box-shadow: 0 2px 17px 3px rgba(0, 0, 0, 0.1) !important;
    box-shadow: 0 2px 17px 3px rgba(0, 0, 0, 0.1) !important;
    background: #fff !important;
    min-height: 300px;
    padding: 30px 100px !important;
    width: 100%;
}

.contact-form-right form {
    width: 100% !important;
}

.contact-form-right input[type=text],
.contact-form-right input[type=email],
.contact-form-right textarea {
    border: 0 !important;
    border-radius: 10px !important;
    background: #f6f6f6 !important;
    width: 100% !important;
    padding: 15px 20px !important;
    margin-bottom: 30px !important;
    font-size: 16px;
}

.contact-form-right textarea {
    resize: none !important;
    height: 130px !important;
}

.contact-form-right h3 {
    font-size: 20px !important;
    margin-bottom: 65px !important;
}

.contact-form-right input[type=submit] {
    padding: 11px 25px !important;
    border-width: 2px !important;
    border-radius: 10px !important;
    font-size: 16px !important;
    color: #fff !important;
    -webkit-transition: all 0.3s ease-out;
    -moz-transition: all 0.3s ease-out;
    -o-transition: all 0.3s ease-out;
    transition: all 0.3s ease-out;
}

#contacts .et_pb_row {
    display: flex;
    flex-wrap: wrap;
}

#contacts .et_pb_column {
    display: flex;
}

/* =========================================================
   CUSTOM HOME PAGE + PROJECTS + CONTACTS
   ---------------------------------------------------------
   ВАЖЛИВО:
   1. Цей блок замінює ВСЕ, що було нижче:
      - HOME PAGE CLEAN VERSION
      - FIX: HEADER + HERO
      - BIGGER HERO IMAGE
      - CONTACTS / SOCIALS PRETTY
   2. Усі стилі нижче ізольовані через:
      .page-template-page-home
   3. Старі стилі теми вище у файлі не чіпаємо.
   ========================================================= */


/* =========================================================
   1. HOME PAGE — BASE LAYOUT
   ========================================================= */

.page-template-page-home .block-area {
    padding: 48px 0;
}

.page-template-page-home .content-section {
    background: #fff;
}

.page-template-page-home .content-section:nth-of-type(even) {
    background: #f7f9fb;
}

.page-template-page-home .section-inner {
    max-width: 760px;
    margin: 0 auto;
}

.page-template-page-home .section-title {
    margin-bottom: 24px;
    font-size: 32px;
    line-height: 1.3;
    font-weight: 700;
    text-align: center;
    color: #0f172a;
}

.page-template-page-home .section-content {
    font-size: 18px;
    line-height: 1.75;
    color: #334155;
}

.page-template-page-home .section-content p:last-child {
    margin-bottom: 0;
}


/* =========================================================
   2. HEADER FIX FOR HOME
   ---------------------------------------------------------
   Вирівнюємо логотип, меню і відступ під fixed header
   ========================================================= */

header {
    height: 120px;
    display: flex;
    align-items: center;
}

#top {
    margin-top: 120px;
}

header .container,
#masthead .container {
    height: 100%;
    display: flex;
    align-items: center;
}

header .row,
#masthead .row {
    width: 100%;
    display: flex;
    align-items: center;
}

header .logo-box,
#masthead .logo-box {
    height: 100%;
    display: flex;
    align-items: center;
}

header .logo-box img,
#masthead .logo-box img {
    width: auto;
    height: auto;
    max-height: 96px;
    object-fit: contain;
}

.topnav-box {
    height: 100%;
    margin-top: 0;
    display: flex;
    align-items: center;
    justify-content: flex-end;
}

.topnav-box #menu-header {
    margin: 0;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 26px;
}

.topnav-box #menu-header > li {
    margin-left: 0;
    display: flex;
    align-items: center;
}

.topnav-box #menu-header > li a {
    display: block;
    padding: 8px 0;
    line-height: 1.2;
    font-size: 16px;
    font-weight: 500;
}


/* =========================================================
   3. HERO
   ========================================================= */

.page-template-page-home .hero-section {
    position: relative;
    min-height: 82vh;
    padding: 0;
    overflow: hidden;
    display: flex;
    align-items: center;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center center;
}

.page-template-page-home .hero-section .container {
    position: relative;
    z-index: 2;
    width: 100%;
}

.page-template-page-home .hero-overlay {
    position: absolute;
    inset: 0;
    z-index: 1;
    background: rgba(15, 23, 42, 0.45);
}

.page-template-page-home .hero-content {
    min-height: 82vh;
    display: flex;
    align-items: center;
    padding: 70px 0 60px;
}

.page-template-page-home .hero-box {
    max-width: 760px;
    color: #fff;
}

.page-template-page-home .hero-box h1 {
    margin-bottom: 20px;
    font-size: 60px;
    line-height: 1.08;
    color: #fff;
}

.page-template-page-home .hero-box p {
    margin-bottom: 0;
    font-size: 24px;
    line-height: 1.5;
    color: #fff;
}


/* =========================================================
   4. CONTENT BLOCKS
   ========================================================= */

/* Про нас */
.page-template-page-home .pro-nas .section-inner {
    max-width: 760px;
}

/* Місія */
.page-template-page-home .misia .section-content {
    padding-left: 18px;
    border-left: 4px solid #0dd1b0;
    font-weight: 500;
    color: #1e293b;
}

/* Що ми робимо / Для кого */
.page-template-page-home .what-we-do ul,
.page-template-page-home .audience ul {
    padding-left: 22px;
}

.page-template-page-home .what-we-do li,
.page-template-page-home .audience li {
    margin-bottom: 10px;
}

/* Цінності */
.page-template-page-home .values .section-content {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}

.page-template-page-home .values .section-content p {
    margin: 0;
    padding: 10px 14px;
    border-radius: 8px;
    background: #f0f3f7;
    color: #243447;
}


/* =========================================================
   5. PROJECTS GRID
   ========================================================= */

.page-template-page-home .projects .section-inner {
    max-width: 1040px;
}

.page-template-page-home .projects-grid {
    margin-top: 30px;
    display: grid;
    grid-template-columns: repeat(2, minmax(280px, 360px));
    justify-content: center;
    gap: 30px;
}

.page-template-page-home .project-card {
    overflow: hidden;
    background: #fff;
    border: 1px solid #e5e7eb;
    border-radius: 14px;
    box-shadow: 0 8px 24px rgba(15, 23, 42, 0.06);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.page-template-page-home .project-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 30px rgba(15, 23, 42, 0.10);
}

.page-template-page-home .project-card-image {
    display: block;
}

.page-template-page-home .project-card-image img {
    width: 100%;
    height: 220px;
    object-fit: cover;
}

.page-template-page-home .project-card-content {
    padding: 22px;
}

.page-template-page-home .project-card-title {
    margin: 0 0 12px;
    font-size: 22px;
    line-height: 1.35;
}

.page-template-page-home .project-card-title a {
    color: #0f172a;
}

.page-template-page-home .project-card-title a:hover {
    color: #0dd1b0;
}

.page-template-page-home .project-card-text {
    margin-bottom: 18px;
    font-size: 16px;
    line-height: 1.65;
    color: #475569;
}

.page-template-page-home .project-card-button {
    display: inline-block;
    padding: 10px 16px;
    border-radius: 8px;
    background: #0f172a;
    color: #fff;
    transition: all 0.2s ease;
}

.page-template-page-home .project-card-button:hover {
    background: #0dd1b0;
    color: #0f172a;
}

.page-template-page-home .projects-empty {
    margin-top: 20px;
    padding: 18px 20px;
    border: 1px dashed #cbd5e1;
    border-radius: 10px;
    background: #f8fafc;
    color: #475569;
}


/* =========================================================
   6. CONTACTS / SOCIALS
   ---------------------------------------------------------
   Тут один фінальний стиль без старих дублювань
   ========================================================= */

.page-template-page-home .contacts {
    padding: 70px 0 80px;
    background: linear-gradient(180deg, #f7fafc 0%, #eef4f8 100%);
    color: #243447;
}

.page-template-page-home .contacts .section-inner {
    max-width: 960px;
    margin: 0 auto;
    text-align: center;
}

.page-template-page-home .contacts .section-title {
    margin-bottom: 40px;
    font-size: 42px;
    line-height: 1.2;
    font-weight: 700;
    color: #16324f;
}

.page-template-page-home .contacts .section-content {
    font-size: 18px;
    line-height: 1.8;
    color: #466177;
}

/* якщо використовується simple layout без карток */
.page-template-page-home .contacts .section-content p {
    margin-bottom: 14px;
}

.page-template-page-home .contacts .section-content strong {
    color: #16324f;
    font-weight: 700;
}

.page-template-page-home .contacts .section-content a {
    color: #14b8a6;
    font-weight: 600;
    border-bottom: 1px solid transparent;
    transition: all 0.2s ease;
}

.page-template-page-home .contacts .section-content a:hover {
    color: #0f766e;
    border-bottom-color: #0f766e;
}

/* якщо в HTML вже є social-grid / social-card */
.page-template-page-home .social-grid,
.page-template-page-home .socials-grid {
    max-width: 760px;
    margin: 20px auto 0;
    display: grid;
    grid-template-columns: repeat(2, minmax(240px, 1fr));
    gap: 28px;
}

.page-template-page-home .social-card {
    padding: 28px 24px;
    border: 1px solid #e3edf3;
    border-radius: 20px;
    background: #fff;
    box-shadow: 0 12px 30px rgba(15, 23, 42, 0.08);
    transition: transform 0.25s ease, box-shadow 0.25s ease, background 0.25s ease;
}

.page-template-page-home .social-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 16px 34px rgba(15, 23, 42, 0.12);
}

.page-template-page-home .social-icon,
.page-template-page-home .social-card-icon {
    width: 58px;
    height: 58px;
    margin: 0 auto 14px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #ecfeff;
    color: #14b8a6;
    font-size: 28px;
    transition: all 0.25s ease;
}

.page-template-page-home .social-title,
.page-template-page-home .social-card-title {
    margin-bottom: 10px;
    font-size: 28px;
    line-height: 1.2;
    font-weight: 700;
    color: #16324f;
}

.page-template-page-home .social-text,
.page-template-page-home .social-card-text {
    margin-bottom: 18px;
    font-size: 17px;
    line-height: 1.6;
    color: #557086;
}

.page-template-page-home .social-link,
.page-template-page-home .social-card-button {
    display: inline-block;
    padding: 12px 20px;
    border-radius: 12px;
    background: #14b8a6;
    color: #fff !important;
    font-size: 16px;
    font-weight: 700;
    transition: all 0.25s ease;
}

.page-template-page-home .social-link:hover,
.page-template-page-home .social-card-button:hover {
    background: #0f766e;
    color: #fff !important;
    border-bottom-color: transparent !important;
}

/* brand hover */
.page-template-page-home .social-card.facebook:hover {
    background: linear-gradient(135deg, #1877f2, #0d5fd1);
}

.page-template-page-home .social-card.instagram:hover {
    background: linear-gradient(45deg, #f58529, #dd2a7b, #8134af);
}

.page-template-page-home .social-card.facebook:hover .social-title,
.page-template-page-home .social-card.facebook:hover .social-text,
.page-template-page-home .social-card.facebook:hover .social-icon,
.page-template-page-home .social-card.instagram:hover .social-title,
.page-template-page-home .social-card.instagram:hover .social-text,
.page-template-page-home .social-card.instagram:hover .social-icon {
    color: #fff;
}

.page-template-page-home .social-card.facebook:hover .social-icon,
.page-template-page-home .social-card.instagram:hover .social-icon {
    background: rgba(255, 255, 255, 0.16);
}

.page-template-page-home .social-card.facebook:hover .social-link,
.page-template-page-home .social-card.instagram:hover .social-link,
.page-template-page-home .social-card.facebook:hover .social-card-button,
.page-template-page-home .social-card.instagram:hover .social-card-button {
    background: rgba(255, 255, 255, 0.18);
    color: #fff !important;
}


/* =========================================================
   7. SINGLE PROJECT
   ========================================================= */

.single-project-page {
    padding: 60px 0;
    background: #f7f9fb;
}

.single-project-inner {
    max-width: 860px;
    margin: 0 auto;
    padding: 40px;
    border-radius: 14px;
    background: #fff;
    box-shadow: 0 10px 30px rgba(15, 23, 42, 0.08);
}

.single-project-title {
    margin: 0 0 24px;
    font-size: 38px;
    line-height: 1.2;
    color: #0f172a;
}

.single-project-image {
    margin-bottom: 25px;
}

.single-project-image img {
    width: 100%;
    height: auto;
    border-radius: 12px;
}

.single-project-excerpt {
    margin-bottom: 25px;
    padding-left: 18px;
    border-left: 4px solid #0dd1b0;
    font-size: 20px;
    line-height: 1.6;
    font-weight: 500;
    color: #334155;
}

.single-project-content {
    font-size: 18px;
    line-height: 1.8;
    color: #1e293b;
}

.single-project-content p {
    margin-bottom: 16px;
}

.single-project-content h2,
.single-project-content h3,
.single-project-content h4 {
    margin-top: 30px;
    margin-bottom: 14px;
    color: #0f172a;
}

.single-project-back {
    margin-top: 35px;
}

.single-project-back-button {
    display: inline-block;
    padding: 12px 18px;
    border-radius: 8px;
    background: #0f172a;
    color: #fff;
    transition: all 0.2s ease;
}

.single-project-back-button:hover {
    background: #0dd1b0;
    color: #0f172a;
}


/* =========================================================
   8. FOOTER TWEAK
   ========================================================= */

.site-footer {
    margin-top: 0;
}


/* =========================================================
   9. RESPONSIVE
   ---------------------------------------------------------
   Усі адаптивні правила зібрані в одному місці
   ========================================================= */

@media (max-width: 1200px) {
    #masthead .logo-box img {
        max-width: 100%;
        width: auto;
        height: auto;
    }

    .contact-form-right {
        padding: 30px 50px !important;
        margin-left: 70px !important;
    }
}

@media (max-width: 992px) {
    .et-db #et-boc .et_pb_toggle_close .et_pb_toggle_title,
    .et-db #et-boc .et_pb_toggle_close h5.et_pb_toggle_title {
        font-size: 14px;
    }

    #annotation #et-boc .et_pb_accordion .et_pb_toggle {
        font-size: 12px;
    }

    #contacts .et_pb_row {
        display: block;
    }

    #contacts .et_pb_column {
        width: 100% !important;
    }

    .contact-form-left {
        width: 100%;
        margin-bottom: 20px !important;
    }

    .contact-form-right {
        margin-left: 0 !important;
    }

    header {
        height: 100px;
    }

    #top {
        margin-top: 100px;
    }

    #masthead .logo-box img,
    header .logo-box img {
        max-height: 78px;
    }

    .topnav-box {
        position: relative;
        display: flex;
        width: 30px;
        height: 30px;
        float: right;
    }

    .topnav-box:before {
        content: '';
        position: absolute;
        width: 30px;
        height: 30px;
        background-image: url("images/menu.svg");
        background-repeat: no-repeat;
        background-position: center center;
        background-size: cover;
    }

    .menu-header-container {
        position: fixed;
        top: 100px;
        right: 0;
        width: 100%;
        height: 100%;
        z-index: 999999;
        display: none;
        background: rgba(255, 255, 255, 0.8);
        transition: all .2s ease-out;
    }

    .topnav-box #menu-header {
        width: 100%;
        max-width: 320px;
        margin-right: 40px;
        display: flex;
        flex-direction: column;
        justify-content: center;
        float: right;
        gap: 0;
        background: #fff;
        border-top: 1px solid #ccc;
    }

    .topnav-box #menu-header > li {
        height: 40px;
        margin-left: 0;
        display: flex;
        align-items: center;
        justify-content: center;
        border-right: 1px solid #ccc;
        border-bottom: 1px solid #ccc;
        border-left: 1px solid #ccc;
    }

    .head-block h1 {
        font-size: 38px;
        line-height: 70px;
    }

    .head-block .title-block::before {
        width: 100%;
        max-width: 900px;
    }

    .page-template-page-home .block-area {
        padding: 40px 0;
    }

    .page-template-page-home .section-title {
        font-size: 28px;
    }

    .page-template-page-home .hero-section {
        min-height: 68vh;
    }

    .page-template-page-home .hero-content {
        min-height: 68vh;
        padding: 60px 0 40px;
    }

    .page-template-page-home .hero-box h1 {
        font-size: 42px;
    }

    .page-template-page-home .hero-box p {
        font-size: 18px;
    }

    .page-template-page-home .projects-grid {
        grid-template-columns: repeat(2, minmax(240px, 1fr));
        gap: 24px;
    }
}

@media (max-width: 768px) {
    .single-project-page {
        padding: 40px 0;
    }

    .single-project-inner {
        max-width: 92%;
        padding: 24px;
    }

    .single-project-title {
        font-size: 28px;
    }

    .single-project-excerpt {
        font-size: 18px;
    }

    .single-project-content {
        font-size: 16px;
    }

    .page-template-page-home .contacts {
        padding: 55px 0 60px;
    }

    .page-template-page-home .contacts .section-title {
        font-size: 34px;
        margin-bottom: 28px;
    }

    .page-template-page-home .social-grid,
    .page-template-page-home .socials-grid {
        grid-template-columns: 1fr;
        max-width: 450px;
        margin-left: auto;
        margin-right: auto;
        gap: 20px;
    }
}

@media (max-width: 620px) {
    .head-block .title-block {
        padding: 0;
    }

    .head-block .title-block::before {
        left: 0;
    }
}

@media (max-width: 576px) {
    header {
        height: 90px;
    }

    #top {
        margin-top: 90px;
    }

    #masthead .logo-box img,
    header .logo-box img {
        max-height: 64px;
    }

    .page-template-page-home .section-inner {
        max-width: 92%;
    }

    .page-template-page-home .hero-section {
        min-height: 52vh;
        background-position: center center;
    }

    .page-template-page-home .hero-content {
        min-height: 52vh;
        padding: 35px 0 25px;
    }

    .page-template-page-home .hero-box {
        max-width: 92%;
    }

    .page-template-page-home .hero-box h1 {
        font-size: 30px;
    }

    .page-template-page-home .hero-box p {
        font-size: 16px;
    }

    .page-template-page-home .projects .section-inner {
        max-width: 92%;
    }

    .page-template-page-home .projects-grid {
        grid-template-columns: 1fr;
        gap: 20px;
    }

    .page-template-page-home .project-card-image img {
        height: 200px;
    }

    .page-template-page-home .contacts .section-title {
        font-size: 28px;
    }

    .page-template-page-home .social-card {
        padding: 22px 18px;
    }

    .page-template-page-home .social-title,
    .page-template-page-home .social-card-title {
        font-size: 24px;
    }
}

@media (max-width: 575px) {
    header {
        top: 0;
    }
}
/* =========================================================
   SOCIALS — FINAL CLEAN
   ========================================================= */

.page-template-page-home .social-buttons {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    margin-top: 16px;
}

.page-template-page-home .social-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;

    width: 240px; /* однакова ширина */
    padding: 8px 14px;

    border-radius: 999px;

    font-size: 14px;
    font-weight: 600;

    background: #f1f5f9;
    color: #0f172a;

    transition: all 0.2s ease;
}

/* іконка */
.page-template-page-home .social-btn .icon {
    width: 20px;
    height: 20px;

    display: flex;
    align-items: center;
    justify-content: center;

    border-radius: 50%;
    background: #e2e8f0;

    font-size: 12px;
}

/* hover */
.page-template-page-home .social-btn:hover {
    transform: translateY(-2px);
}

/* Facebook */
.page-template-page-home .social-btn.facebook:hover {
    background: #1877f2;
    color: #fff;
}

/* Instagram */
.page-template-page-home .social-btn.instagram:hover {
    background: linear-gradient(45deg, #f58529, #dd2a7b, #8134af);
    color: #fff;
}
/* =========================================================
   WHAT WE DO — LIGHT CARDS
   ========================================================= */

.page-template-page-home .what-we-do .section-inner {
    max-width: 980px;
}

.page-template-page-home .what-cards {
    display: grid;
    grid-template-columns: repeat(2, minmax(280px, 1fr));
    gap: 22px;
    margin-top: 10px;
}

.page-template-page-home .what-card {
    padding: 22px 20px;
    border-radius: 14px;
    background: #ffffff;
    border: 1px solid #e5e7eb;
    transition: all 0.2s ease;
}

.page-template-page-home .what-card:hover {
    transform: translateY(-3px);
    border-color: #cbd5e1;
}

.page-template-page-home .what-card-icon {
    width: 44px;
    height: 44px;
    margin-bottom: 14px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #ecfeff;
    color: #14b8a6;
    font-size: 18px;
    line-height: 1;
}

.page-template-page-home .what-card-title {
    margin: 0 0 10px;
    font-size: 22px;
    line-height: 1.3;
    font-weight: 700;
    color: #16324f;
}

.page-template-page-home .what-card-text {
    font-size: 16px;
    line-height: 1.6;
    color: #557086;
}


@media (max-width: 767px) {
    .page-template-page-home .what-cards {
        grid-template-columns: 1fr;
        gap: 18px;
    }

    .page-template-page-home .what-card {
        padding: 18px 16px;
        border-radius: 12px;
    }

    .page-template-page-home .what-card-icon {
        width: 36px;
        height: 36px;
        margin-bottom: 12px;
        font-size: 14px;
    }

    .page-template-page-home .what-card-title {
        margin-bottom: 8px;
        font-size: 20px;
    }

    .page-template-page-home .what-card-text {
        font-size: 15px;
        line-height: 1.55;
    }
}
/* =========================================================
   AUDIENCE — CLEAN LIST
   ========================================================= */

.page-template-page-home .audience .section-inner {
    max-width: 980px;
}

.page-template-page-home .audience-item-modern {
    position: relative;
    padding-left: 18px;
    transition: transform 0.2s ease;
}

.page-template-page-home .audience-item-modern:hover {
    transform: translateX(4px);
}

.page-template-page-home .audience-item-modern::before {
    content: "";
    position: absolute;
    left: 0;
    top: 7px;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: #14b8a6;
}
/* =========================================================
   VALUES / ЦІННОСТІ
   Легкий список у 2 колонки без карток
   ========================================================= */

.page-template-page-home .values .section-inner {
    max-width: 980px;
}

.page-template-page-home .values .section-content {
    display: block;
}

.page-template-page-home .values-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(280px, 1fr));
    gap: 22px 34px;
    margin-top: 10px;
}

.page-template-page-home .value-item {
    position: relative;
    padding: 0 0 0 18px;
}

.page-template-page-home .value-item::before {
    content: "";
    position: absolute;
    left: 0;
    top: 6px;
    width: 6px;
    height: calc(100% - 12px);
    border-radius: 999px;
    background: #14b8a6;
}

.page-template-page-home .value-item-title {
    margin-bottom: 8px;
    font-size: 22px;
    line-height: 1.3;
    font-weight: 700;
    color: #16324f;
}

.page-template-page-home .value-item-text {
    font-size: 16px;
    line-height: 1.7;
    color: #557086;
}

@media (max-width: 767px) {
    .page-template-page-home .values-list {
        grid-template-columns: 1fr;
        gap: 18px;
    }

    .page-template-page-home .value-item-title {
        font-size: 20px;
    }
}
.value-item {
    transition: transform 0.2s ease, color 0.2s ease;
}

.value-item:hover {
    transform: translateX(4px);
}
/* =========================================================
   MOBILE MENU FIX
   ========================================================= */

@media (max-width: 992px) {

    /* контейнер мобільного меню */
    .menu-header-container {
        position: fixed;
        top: 100px;
        left: 0;
        right: 0;
        width: 100%;
        height: calc(100vh - 100px);
        padding: 20px;
        background: rgba(255, 255, 255, 0.98);
        overflow-y: auto;
        z-index: 9999;
    }

    /* сам список */
    .topnav-box #menu-header {
        display: flex !important;
        flex-direction: column !important;
        align-items: stretch !important;
        justify-content: flex-start !important;
        gap: 12px !important;
        width: 100% !important;
        max-width: 420px;
        margin: 0 auto !important;
        padding: 0 !important;
        list-style: none !important;
    }

    /* елемент списку */
    .topnav-box #menu-header > li {
        display: block !important;
        width: 100% !important;
        margin: 0 !important;
    }

    /* посилання */
    .topnav-box #menu-header > li > a {
        display: block !important;
        width: 100% !important;
        padding: 16px 18px !important;
        border: 1px solid #e5e7eb;
        border-radius: 12px;
        background: #ffffff;
        color: #0f172a !important;
        font-size: 18px !important;
        line-height: 1.3 !important;
        font-weight: 600;
        text-align: center;
        box-shadow: 0 4px 14px rgba(15, 23, 42, 0.06);
    }

    .topnav-box #menu-header > li > a:hover {
        background: #0dd1b0;
        color: #0f172a !important;
    }

    /* якщо є підменю */
    .topnav-box #menu-header .sub-menu {
        position: static !important;
        display: block !important;
        width: 100% !important;
        margin-top: 8px !important;
        padding-left: 0 !important;
        box-shadow: none !important;
        background: transparent !important;
    }

    .topnav-box #menu-header .sub-menu li {
        width: 100% !important;
        margin: 8px 0 0 0 !important;
    }

    .topnav-box #menu-header .sub-menu a {
        display: block !important;
        width: 100% !important;
        padding: 12px 16px !important;
        border-radius: 10px;
        background: #f8fafc;
        border: 1px solid #e5e7eb;
        text-align: center;
    }
}


/* =========================================================
   HERO IMPROVE
   ========================================================= */

.page-template-page-home .hero-overlay {
    background: rgba(15, 23, 42, 0.65);
}

.page-template-page-home .hero-box {
    position: relative;
    max-width: 640px;
    color: #fff;
}

.page-template-page-home .hero-box::before {
    content: "";
    position: absolute;
    inset: -20px;
    background: rgba(15, 23, 42, 0.32);
    filter: blur(40px);
    z-index: -1;
}

.page-template-page-home .hero-box h1 {
    margin-bottom: 20px;
    font-size: 60px;
    line-height: 1.08;
    color: #ffffff;
}

.page-template-page-home .hero-box h1 span {
    color: #14b8a6;
}

.page-template-page-home .hero-box p {
    margin-bottom: 0;
    font-size: 22px;
    line-height: 1.5;
    color: rgba(255, 255, 255, 0.88);
}

.page-template-page-home .hero-btn {
    display: inline-block;
    margin-top: 24px;
    padding: 12px 22px;
    border-radius: 10px;
    background: #14b8a6;
    color: #fff !important;
    font-size: 16px;
    font-weight: 600;
    transition: all 0.2s ease;
}

.page-template-page-home .hero-btn:hover {
    background: #0f766e;
    color: #fff !important;
}