/*
Theme Name: IndProject (Light Version)
Theme URI: https://indproject.gr
Author: IndProject
Author URI: https://indproject.gr
Description: Премиальная тема для строительной компании IndProject — строительство роскошных вилл в Греции. Светлая версия с контрастами.
Version: 2.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: indproject
Tags: custom-background, custom-logo, featured-images, threaded-comments, translation-ready, one-column
Requires at least: 6.0
Requires PHP: 7.4
*/
:root {
    --bg: #24292D;
    --bg2: #1B2024;
    --card: #1A1F23;
    --card2: #161920;
    --footer: #151920;
    --a: #c9a96e;
    --al: #e0c992;
    --ad: #a8863f;
    --t1: #f0ece4;
    --t2: #9a968e;
    --t3: #5a574f;
    --b: #1B2024;
    --b2: #1A1F23;
    --border: #383E44;
    --border2: #3F454D;
    --fd: 'Cormorant Garamond', Georgia, serif;
    --fb: 'Outfit', sans-serif;
    --e: cubic-bezier(.25, .46, .45, .94);
    --wp-admin-bar-height: 32px;
    --container-max-width: 1300px;
}
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; overflow-x: hidden; }
body { font-family: var(--fb); background: var(--bg); color: var(--t1); line-height: 1.7; overflow-x: hidden; -webkit-font-smoothing: antialiased; }
::selection { background: var(--a); color: var(--bg); }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; height: auto; display: block; }
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb { background: var(--ad); border-radius: 3px; }
.alignleft { float: left; margin-right: 1.5em; }
.alignright { float: right; margin-left: 1.5em; }
.aligncenter { clear: both; display: block; margin-left: auto; margin-right: auto; }
.admin-bar .nav { top: 32px; }
@media (max-width: 782px) { .admin-bar .nav { top: 46px; } }
.nav { position: fixed; top: 0; left: 0; width: 100%; z-index: 1000; padding: 1.5rem 3rem; display: flex; justify-content: space-between; align-items: center; transition: background .5s var(--e), padding .5s var(--e), backdrop-filter .5s var(--e); }
.nav.scrolled { background: rgba(27,32,36,.95); backdrop-filter: blur(20px); padding: 1rem 3rem; border-bottom: 1px solid var(--border2); transition: background .5s var(--e), padding .5s var(--e), backdrop-filter .5s var(--e), border-bottom 0s; }
.logo { font-family: var(--fd); font-size: 1.6rem; font-weight: 300; letter-spacing: .3em; text-transform: uppercase; }
.logo b { color: var(--a); font-weight: 600; }
.nl { display: flex; gap: 2.5rem; list-style: none; }
.nl li { list-style: none; }
.nl a { font-size: .8rem; font-weight: 400; letter-spacing: .15em; text-transform: uppercase; color: rgba(218,218,218); transition: color .3s; position: relative; }
.nl a::after { content: ''; position: absolute; bottom: -4px; left: 0; width: 0; height: 1px; background: var(--a); transition: width .4s var(--e); }
.nl a:hover { color: var(--a); }
.nl a:hover::after { width: 100%; }
.nl .current-menu-item a, .nl .current_page_item a, .nl a.active { color: var(--a); }
.nl .current-menu-item a::after, .nl .current_page_item a::after, .nl a.active::after { width: 100%; }
.burger { display: none; flex-direction: column; gap: 5px; cursor: pointer; z-index: 1001; background: none; border: none; padding: 5px; }
.burger span { width: 28px; height: 1.5px; background: var(--t1); transition: all .4s var(--e); display: block; }
.burger.on span:nth-child(1) { transform: rotate(45deg) translate(4px, 5px); }
.burger.on span:nth-child(2) { opacity: 0; }
.burger.on span:nth-child(3) { transform: rotate(-45deg) translate(4px, -5px); }
.mm { position: fixed; top: 0; right: -100%; width: 100%; height: 100vh; background: rgba(27,32,36,.98); backdrop-filter: blur(30px); display: flex; flex-direction: column; justify-content: center; align-items: center; gap: 2rem; transition: right .6s var(--e); z-index: 999; }
.mm.on { right: 0; }
.mm li { list-style: none; }
.mm a, .mm .mobile-nav a { font-family: var(--fd); font-size: 2.5rem; font-weight: 300; color: var(--t2); transition: all .3s; display: block; }
.mm a:hover, .mm .mobile-nav a:hover { color: var(--a); transform: translateX(10px); }
.mm .mobile-nav { list-style: none; display: flex; flex-direction: column; align-items: center; gap: 2rem; }
.hero { position: relative; height: 100vh; min-height: 700px; display: flex; align-items: center; justify-content: center; overflow: hidden; }
.hero-content { position: relative; z-index: 2; text-align: center; max-width: 900px; padding: 0 2rem; width: 100%; }
.hscr { position: absolute; bottom: 1.5rem; left: 0; right: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: .75rem; opacity: 0; animation: fu 1s var(--e) 1.2s forwards; z-index: 10; width: 100%; }
.hero-photo { position: absolute; inset: 0; z-index: 0; background-size: cover; background-position: center; }
.hero-photo::after { content: ''; position: absolute; inset: 0; background: linear-gradient(to bottom, rgba(36,41,45,.3), rgba(36,41,45,.6) 70%, rgba(36,41,45,.9)); }
.hero-photo--default { background: radial-gradient(ellipse at 25% 60%, rgba(42,64,85,.6), transparent 50%), radial-gradient(ellipse at 75% 40%, rgba(30,48,69,.5), transparent 50%), linear-gradient(160deg, #24292D, #24292D 30%, #24292D 50%, #1A1F23 80%, #1B2024); opacity: .3; }
.hero-bg { position: absolute; inset: 0; z-index: 1; background: linear-gradient(135deg, rgba(36,41,45,.7), rgba(27,32,36,.5), rgba(36,41,45,.7)); }
.hero-bg::after { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse at 30% 50%, rgba(201,169,110,.08), transparent 60%), radial-gradient(ellipse at 70% 30%, rgba(201,169,110,.04), transparent 50%); }
.hd { position: absolute; width: 400px; height: 400px; border: 1px solid rgba(201,169,110,.07); border-radius: 50%; top: 50%; left: 50%; transform: translate(-50%,-50%); animation: sp 40s linear infinite; z-index: 2; }
.hd::before { content: ''; position: absolute; width: 320px; height: 320px; border: 1px solid rgba(201,169,110,.05); border-radius: 50%; top: 50%; left: 50%; transform: translate(-50%,-50%); }
.hd::after { content: ''; position: absolute; width: 500px; height: 500px; border: 1px solid rgba(201,169,110,.04); border-radius: 50%; top: 50%; left: 50%; transform: translate(-50%,-50%); }
@keyframes sp { to { transform: translate(-50%,-50%) rotate(360deg); } }
.hl { position: absolute; inset: 0; overflow: hidden; z-index: 2; }
.hl i { position: absolute; width: 1px; background: linear-gradient(to bottom, transparent, var(--a), transparent); opacity: .06; animation: lf 8s ease-in-out infinite; }
.hl i:nth-child(1) { left: 15%; height: 60%; top: 20%; }
.hl i:nth-child(2) { left: 35%; height: 40%; top: 30%; animation-delay: 2s; }
.hl i:nth-child(3) { left: 65%; height: 50%; top: 25%; animation-delay: 4s; }
.hl i:nth-child(4) { left: 85%; height: 45%; top: 20%; animation-delay: 6s; }
@keyframes lf { 0%, 100% { opacity: .03; transform: translateY(0); } 50% { opacity: .08; transform: translateY(-20px); } }

.hero-content .badge { display: inline-flex; align-items: center; gap: .75rem; border: 1px solid rgba(218,218,218); padding: .5rem 1.5rem; border-radius: 100px; margin-bottom: 2.5rem; opacity: 0; transform: translateY(20px); animation: fu 1s var(--e) .3s forwards; }
.badge .dot { width: 6px; height: 6px; background: var(--a); border-radius: 50%; animation: pu 2s ease-in-out infinite; }
@keyframes pu { 0%, 100% { opacity: 1; } 50% { opacity: .4; } }
.badge span { font-size: .7rem; letter-spacing: .2em; text-transform: uppercase; color: var(--t2); }
.hero-content h1 { font-family: var(--fd); font-size: clamp(2.8rem, 7vw, 6rem); font-weight: 300; line-height: 1.1; margin-bottom: 1.5rem; opacity: 0; transform: translateY(30px); animation: fu 1s var(--e) .5s forwards; }
.hero h1 em { font-style: italic; color: var(--a); }
.hero-content .hsub { font-size: 1.05rem; font-weight: 300; color: rgba(218,218,218,.8); max-width: 600px; margin: 0 auto 3rem; line-height: 1.8; opacity: 0; transform: translateY(30px); animation: fu 1s var(--e) .7s forwards; }
.hero-content .hcta { display: inline-flex; gap: 1.5rem; opacity: 0; transform: translateY(30px); animation: fu 1s var(--e) .9s forwards; }
@keyframes fu { to { opacity: 1; transform: translateY(0); } }
.hscr { position: absolute; bottom: 1rem; left: 0; right: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: .75rem; opacity: 0; animation: fu 1s var(--e) 1.2s forwards; z-index: 10; width: 100%; }
.hscr span { font-size: .65rem; letter-spacing: .2em; text-transform: uppercase; color: var(--t3); }
.scroll-line { width: 1px; height: 40px; background: var(--border); position: relative; overflow: hidden; }
.scroll-line::after { content: ''; position: absolute; top: -100%; left: 0; width: 100%; height: 50%; background: var(--a); animation: sd 2s ease-in-out infinite; }
@keyframes sd { 0% { top: -50%; } 100% { top: 100%; } }
.btn { display: inline-flex; align-items: center; gap: .75rem; padding: 1rem 2.5rem; font-family: var(--fb); font-size: .8rem; font-weight: 500; letter-spacing: .15em; text-transform: uppercase; border: none; cursor: pointer; transition: all .4s var(--e); white-space: nowrap; }
.bp { background: var(--a); color: var(--bg); }
.bp:hover { background: var(--al); transform: translateY(-2px); box-shadow: 0 10px 30px rgba(201,169,110,.2); }
.bo { background: transparent; color: var(--t1); border: 1px solid rgba(218,218,218,.8); }
.bo:hover { border-color: var(--a); color: var(--a); transform: translateY(-2px); }
.btn:hover .arr { transform: translateX(4px); }
.arr { transition: transform .3s; }
.sec { padding: 8rem 3rem; position: relative; }
.con { max-width: 1300px; margin: 0 auto; }
.sh { max-width: 800px; margin-bottom: 4rem; }
.sh.c { text-align: center; margin-left: auto; margin-right: auto; }
.tag { font-size: .7rem; letter-spacing: .25em; text-transform: uppercase; color: var(--a); margin-bottom: 1.25rem; display: flex; align-items: center; gap: 1rem; }
.sh.c .tag { justify-content: center; }
.tag::before { content: ''; width: 30px; height: 1px; background: var(--a); }
.st { font-family: var(--fd); font-size: clamp(2rem, 4vw, 3.2rem); font-weight: 300; line-height: 1.2; margin-bottom: 1.5rem; }
.st em { font-style: italic; color: var(--a); }
.sd { font-size: 1rem; color: var(--t2); line-height: 1.8; font-weight: 300; }
.bg-secondary { background: var(--bg2); }
.bg-primary { background: var(--bg); }
.ag { display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; align-items: center; }
.aiw { position: relative; aspect-ratio: 4/5; overflow: hidden; }
.aib { width: 100%; height: 100%; background: linear-gradient(135deg, #24292D, #1B2024 30%, #1A1F23 60%, #161920); position: relative; transition: transform .8s var(--e); }
.aib::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse at 70% 40%, rgba(135,180,220,.15), transparent 60%), radial-gradient(circle at 30% 80%, rgba(201,169,110,.1), transparent 40%); }
.aiw:hover .aib { transform: scale(1.05); }
.afr { position: absolute; inset: 1.5rem; border: 1px solid rgba(201,169,110,.2); pointer-events: none; z-index: 1; }
.about-featured-img { width: 100%; height: 100%; object-fit: cover; transition: transform .8s var(--e); }
.aiw:hover .about-featured-img { transform: scale(1.05); }
.as { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; margin-top: 3rem; padding-top: 3rem; border-top: 1px solid var(--border); }
.si { text-align: center; }
.sn { font-family: var(--fd); font-size: 2.8rem; font-weight: 300; color: var(--a); line-height: 1; margin-bottom: .5rem; }
.sl2 { font-size: .75rem; letter-spacing: .1em; text-transform: uppercase; color: var(--t3); }
.aq { font-family: var(--fd); font-size: 1.4rem; font-style: italic; color: var(--al); line-height: 1.5; margin-top: 2rem; padding-left: 1.5rem; border-left: 2px solid var(--a); }
.sg { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; }
.sc { background: var(--card2); border: 1px solid var(--border); padding: 3rem 2.5rem; transition: all .5s var(--e); position: relative; overflow: hidden; }
.sc::before { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 2px; background: linear-gradient(to right, var(--a), transparent); transform: scaleX(0); transform-origin: left; transition: transform .5s var(--e); }
.sc:hover { background: var(--card); border-color: var(--border2); transform: translateY(-5px); }
.sc:hover::before { transform: scaleX(1); }
.si2 { width: 50px; height: 50px; display: flex; align-items: center; justify-content: center; margin-bottom: 2rem; }
.si2 svg { width: 32px; height: 32px; stroke: var(--a); fill: none; stroke-width: 1.5; }
.sc h3 { font-family: var(--fd); font-size: 1.4rem; font-weight: 400; margin-bottom: 1rem; }
.sc p { color: var(--t2); font-size: .95rem; font-weight: 300; line-height: 1.7; }
.al { display: grid; grid-template-columns: 350px 1fr; gap: 4rem; align-items: start; }
.ap { position: relative; overflow: hidden; aspect-ratio: 3/4; }
.apb { width: 100%; height: 100%; background: linear-gradient(160deg, #24292D, #1B2024 40%, #1A1F23); display: flex; align-items: center; justify-content: center; position: relative; }
.apb::after { content: 'SV'; position: absolute; font-family: var(--fd); font-size: 5rem; font-weight: 300; color: rgba(201,169,110,.08); letter-spacing: .2em; }
.ap::before { content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 40%; background: linear-gradient(to top, var(--bg2), transparent); z-index: 1; pointer-events: none; }
.anb { position: absolute; bottom: 1.5rem; left: 1.5rem; z-index: 2; background: rgba(27,32,36,.7); backdrop-filter: blur(10px); padding: .6rem 1.2rem; border: 1px solid var(--border); }
.anb span { font-family: var(--fd); font-size: 1rem; color: var(--al); }
.at h3 { font-family: var(--fd); font-size: 2rem; font-weight: 400; margin-bottom: 1.5rem; }
.at p { color: var(--t2); font-weight: 300; margin-bottom: 1.5rem; line-height: 1.8; }
.architect-featured-img { width: 100%; height: 100%; object-fit: cover; }
.vs { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; }
.vc { position: relative; overflow: hidden; cursor: pointer; background: var(--card2); border: 1px solid var(--border); transition: all .5s var(--e); }
.vc:hover { border-color: rgba(201,169,110,.3); }
.vi { aspect-ratio: 4/3; overflow: hidden; position: relative; }
.vi img { width: 100%; height: 100%; object-fit: cover; transition: transform .8s var(--e), filter .5s; }
.vc:hover .vi img { transform: scale(1.1); filter: brightness(.6); }
.vb { width: 100%; height: 100%; transition: transform .8s var(--e), filter .5s; position: relative; }
.vc:hover .vb { transform: scale(1.1); filter: brightness(.6); }
.v1 { background: linear-gradient(135deg, #24292D, #1B2024 30%, #1A1F23 60%, #161920); }
.v2 { background: linear-gradient(135deg, #24292D, #1B2024 30%, #1A1F23 60%, #161920); }
.v3 { background: linear-gradient(135deg, #24292D, #1B2024 30%, #1A1F23 60%, #161920); }
.v4 { background: linear-gradient(135deg, #24292D, #1B2024 30%, #1A1F23 60%, #161920); }
.v5 { background: linear-gradient(135deg, #24292D, #1B2024 30%, #1A1F23 60%, #161920); }
.v6 { background: linear-gradient(135deg, #24292D, #1B2024 30%, #1A1F23 60%, #161920); }
.v1::after,.v2::after,.v3::after,.v4::after,.v5::after,.v6::after { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse at 60% 40%, rgba(255,255,255,.05), transparent 60%); }
.vn { position: absolute; top: 1rem; left: 1.5rem; font-family: var(--fd); font-size: 4rem; font-weight: 300; color: rgba(201,169,110,.12); line-height: 1; z-index: 1; }
.vo { position: absolute; inset: 0; background: linear-gradient(to top, rgba(27,32,36,.95), rgba(27,32,36,.4) 40%, transparent 60%); display: flex; flex-direction: column; justify-content: flex-end; padding: 2rem; opacity: 0; transition: opacity .5s var(--e); }
.vc:hover .vo { opacity: 1; }
.vo h3 { font-family: var(--fd); font-size: 1.2rem; font-weight: 400; margin-bottom: .5rem; }
.vo p { font-size: .85rem; color: var(--t2); font-weight: 300; line-height: 1.5; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.pg { display: grid; grid-template-columns: repeat(2, 1fr); gap: 2rem; }
.pc { position: relative; overflow: hidden; background: var(--card2); border: 1px solid var(--border); transition: all .5s var(--e); }
.pc:hover { border-color: var(--ad); transform: translateY(-3px); }
.pim { width: 100%; aspect-ratio: 16/10; overflow: hidden; position: relative; }
.pim img { width: 100%; height: 100%; object-fit: cover; transition: transform .8s var(--e); }
.pc:hover .pim img { transform: scale(1.08); }
.pb { width: 100%; height: 100%; transition: transform .8s var(--e); position: relative; }
.pc:hover .pb { transform: scale(1.08); }
.p1 { background: linear-gradient(135deg, #24292D, #1B2024 40%, #1A1F23 70%, #161920); }
.p2 { background: linear-gradient(135deg, #24292D, #1B2024 40%, #1A1F23 70%, #161920); }
.p3 { background: linear-gradient(135deg, #24292D, #1B2024 40%, #1A1F23 70%, #161920); }
.p4 { background: linear-gradient(135deg, #24292D, #1B2024 40%, #1A1F23 70%, #161920); }
.p1::after,.p2::after,.p3::after,.p4::after { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse at 65% 35%, rgba(255,255,255,.06), transparent 55%); }
.ptag { position: absolute; bottom: 1rem; left: 1.5rem; z-index: 2; display: inline-flex; align-items: center; gap: .5rem; background: rgba(27,32,36,.7); backdrop-filter: blur(10px); padding: .4rem 1rem; border-radius: 100px; font-size: .7rem; color: var(--a); letter-spacing: .1em; text-transform: uppercase; }
.ptag svg { width: 12px; height: 12px; stroke: var(--a); fill: none; stroke-width: 2; }
.pim::after { content: ''; position: absolute; inset: 0; background: linear-gradient(to top, rgba(27,32,36,.5), transparent 50%); pointer-events: none; }
.pnf { padding: 2rem 2.5rem; }
.pnf h3 { font-family: var(--fd); font-size: 1.3rem; font-weight: 400; margin-bottom: .75rem; }
.pnf p { font-size: .9rem; color: var(--t2); font-weight: 300; line-height: 1.6; }
.pm { display: flex; flex-wrap: wrap; gap: 1.5rem; margin-top: 1rem; padding-top: 1rem; border-top: 1px solid var(--border); }
.pm span { font-size: .75rem; color: var(--t3); }
.pm span strong { color: var(--t2); font-weight: 500; }
.proj-list { display: flex; flex-direction: column; gap: 3rem; }
.proj-card { display: grid; grid-template-columns: 1fr 1fr; background: var(--card2); border: 1px solid var(--border); overflow: hidden; transition: all .5s var(--e); }
.proj-card:hover { border-color: rgba(201,169,110,.3); transform: translateY(-3px); }
.proj-card:nth-child(even) { direction: rtl; }
.proj-card:nth-child(even) > * { direction: ltr; }
.proj-img { position: relative; min-height: 350px; overflow: hidden; }
.proj-bg { width: 100%; height: 100%; position: absolute; inset: 0; transition: transform .8s var(--e); }
.proj-card:hover .proj-bg { transform: scale(1.05); }
.proj-img img { width: 100%; height: 100%; object-fit: cover; position: absolute; inset: 0; transition: transform .8s var(--e); }
.proj-card:hover .proj-img img { transform: scale(1.05); }
.proj-loc { position: absolute; top: 1.5rem; left: 1.5rem; z-index: 2; display: inline-flex; align-items: center; gap: .5rem; background: rgba(27,32,36,.7); backdrop-filter: blur(10px); padding: .5rem 1rem; border-radius: 100px; font-size: .7rem; color: var(--a); letter-spacing: .1em; text-transform: uppercase; }
.proj-loc svg { width: 14px; height: 14px; stroke: var(--a); fill: none; stroke-width: 2; }
.proj-body { padding: 3rem; }
.proj-body h3 { font-family: var(--fd); font-size: 1.8rem; font-weight: 400; margin-bottom: 1rem; }
.proj-body .desc { color: var(--t2); font-weight: 300; line-height: 1.8; margin-bottom: 2rem; }
.specs { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.spec { padding: 1rem; background: var(--bg); border: 1px solid var(--border); }
.spec .label { font-size: .7rem; letter-spacing: .1em; text-transform: uppercase; color: var(--t3); margin-bottom: .25rem; }
.spec .val { font-family: var(--fd); font-size: 1.15rem; color: var(--al); }
.gg { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; }
.gi { overflow: hidden; position: relative; cursor: pointer; aspect-ratio: 1; }
.gi img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s var(--e), filter .5s; }
.gi:hover img { transform: scale(1.15); filter: brightness(.5); }
.gb { width: 100%; height: 100%; transition: transform .6s var(--e), filter .5s; }
.gi:hover .gb { transform: scale(1.15); filter: brightness(.5); }
.g1 { background: linear-gradient(45deg, #24292D, #1B2024, #24292D); }
.g2 { background: linear-gradient(135deg, #24292D, #1A1F23, #24292D); }
.g3 { background: linear-gradient(45deg, #24292D, #1B2024, #24292D); }
.g4 { background: linear-gradient(135deg, #24292D, #1A1F23, #24292D); }
.g5 { background: linear-gradient(45deg, #24292D, #1B2024, #24292D); }
.g6 { background: linear-gradient(135deg, #24292D, #1A1F23, #24292D); }
.g7 { background: linear-gradient(45deg, #24292D, #1B2024, #24292D); }
.g8 { background: linear-gradient(135deg, #24292D, #1A1F23, #24292D); }
.gic { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%) scale(0); transition: transform .4s cubic-bezier(.34,1.56,.64,1); pointer-events: none; z-index: 2; }
.gi:hover .gic { transform: translate(-50%,-50%) scale(1); }
.gic svg { width: 32px; height: 32px; stroke: var(--a); fill: none; stroke-width: 1.5; }
.gl { position: absolute; bottom: 0; left: 0; right: 0; padding: 1rem; background: linear-gradient(to top, rgba(27,32,36,.8), transparent); font-family: var(--fd); font-size: .85rem; color: var(--t2); opacity: 0; transition: opacity .4s; z-index: 2; }
.gi:hover .gl { opacity: 1; }
.masonry { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; }
.masonry-item { aspect-ratio: 1; position: relative; overflow: hidden; cursor: pointer; background: var(--card2); border: 1px solid var(--border); transition: all .4s var(--e); }
.masonry-item:hover { border-color: rgba(201,169,110,.3); transform: translateY(-2px); }
.masonry-item img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .6s var(--e), filter .5s; }
.masonry-item:hover img { transform: scale(1.08); filter: brightness(.6); }
.masonry-item .m-bg { width: 100%; transition: transform .6s var(--e), filter .5s; }
.masonry-item:hover .m-bg { transform: scale(1.08); filter: brightness(.6); }
.masonry-item .m-label { position: absolute; bottom: 0; left: 0; right: 0; padding: 1rem 1.25rem; background: linear-gradient(to top, rgba(27,32,36,.85), transparent); font-family: var(--fd); font-size: .9rem; color: var(--t2); opacity: 0; transition: opacity .4s; z-index: 2; }
.masonry-item:hover .m-label { opacity: 1; }
.mh1 { aspect-ratio: 1; } .mh2 { aspect-ratio: 3/4; } .mh3 { aspect-ratio: 4/3; } .mh4 { aspect-ratio: 2/3; } .mh5 { aspect-ratio: 5/4; }
.cg { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; }
.ci h3 { font-family: var(--fd); font-size: 2rem; font-weight: 300; margin-bottom: 2rem; }
.ct { display: flex; align-items: flex-start; gap: 1rem; margin-bottom: 1.5rem; padding: 1.25rem; background: var(--card2); border: 1px solid var(--border); transition: all .3s; }
.ct:hover { border-color: var(--ad); }
.cti svg { width: 20px; height: 20px; stroke: var(--a); fill: none; stroke-width: 1.5; }
.cti { flex-shrink: 0; margin-top: 2px; }
.ctx { font-size: .95rem; color: var(--t2); font-weight: 300; }
.ctx strong { display: block; color: var(--t1); font-weight: 500; margin-bottom: .25rem; font-size: .85rem; letter-spacing: .1em; text-transform: uppercase; }
.ctx a { color: var(--al); transition: color .3s; }
.ctx a:hover { color: var(--a); }
.cf, .cf2 { display: flex; flex-direction: column; gap: 1.25rem; }
.fg input, .fg textarea, .fg2 input, .fg2 textarea { width: 100%; padding: 1rem 1.25rem; background: var(--card2); border: 1px solid var(--border); color: var(--t1); font-family: var(--fb); font-size: .9rem; font-weight: 300; outline: none; transition: all .3s; }
.fg input::placeholder, .fg textarea::placeholder, .fg2 input::placeholder, .fg2 textarea::placeholder { color: var(--t3); }
.fg input:focus, .fg textarea:focus, .fg2 input:focus, .fg2 textarea:focus { border-color: var(--a); box-shadow: 0 0 0 1px rgba(201,169,110,.1); }
.fg textarea, .fg2 textarea { min-height: 150px; resize: vertical; }
.fr, .fr2 { display: grid; grid-template-columns: 1fr 1fr; gap: 1.25rem; }
.phero { position: relative; padding: 10rem 3rem 5rem; background: var(--bg2); overflow: hidden; text-align: center; }
.phero::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse at 40% 60%, rgba(201,169,110,.06), transparent 60%);pointer-events: none; }
.phero h1 { font-family: var(--fd); font-size: clamp(2.5rem, 6vw, 4.5rem); font-weight: 300; line-height: 1.15; margin-bottom: 1rem; }
.phero h1 em { font-style: italic; color: var(--a); }
.phero .psub { font-size: 1rem; color: var(--t2); font-weight: 300; max-width: 600px; margin: 0 auto; }
.phero .breadcrumb { margin-top: 1.5rem; font-size: .75rem; letter-spacing: .15em; text-transform: uppercase; color: var(--t3); }
.phero .breadcrumb a { color: var(--t3); transition: color .3s; }
.phero .breadcrumb a:hover { color: var(--a); }
.phero .breadcrumb span { color: var(--a); }
.about-full { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: start; }
.about-full .text-block { color: var(--t2); font-weight: 300; line-height: 1.9; }
.about-full .text-block p { margin-bottom: 1.5rem; }
.about-full .text-block strong { color: var(--t1); font-weight: 500; }
.about-sidebar { background: var(--card2); border: 1px solid var(--border); padding: 3rem; }
.about-sidebar h3 { font-family: var(--fd); font-size: 1.5rem; font-weight: 400; margin-bottom: 2rem; color: var(--al); }
.stat-row { display: flex; justify-content: space-between; padding: 1rem 0; border-bottom: 1px solid var(--border); }
.stat-row:last-child { border-bottom: none; }
.stat-row .stat-label { font-size: .85rem; color: var(--t3); text-transform: uppercase; letter-spacing: .1em; }
.stat-row .stat-value { font-family: var(--fd); font-size: 1.3rem; color: var(--a); font-weight: 400; }
.quote-block { background: var(--card2); border-left: 3px solid var(--a); padding: 2.5rem 3rem; margin: 3rem 0; }
.quote-block p { font-family: var(--fd); font-size: 1.6rem; font-style: italic; color: var(--al); line-height: 1.5; }
.quote-block cite { display: block; margin-top: 1rem; font-size: .8rem; color: var(--t3); font-style: normal; letter-spacing: .1em; text-transform: uppercase; }
.vg2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 2rem; margin-top: 3rem; }
.vc2 { background: var(--card2); border: 1px solid var(--border); overflow: hidden; transition: all .5s var(--e); }
.vc2:hover { border-color: rgba(201,169,110,.3); transform: translateY(-3px); }
.vc2-img { aspect-ratio: 16/9; position: relative; overflow: hidden; }
.vc2-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .8s var(--e); }
.vc2:hover .vc2-img img { transform: scale(1.05); }
.vc2-body { padding: 2rem; }
.vc2-body h3 { font-family: var(--fd); font-size: 1.3rem; font-weight: 400; margin-bottom: .75rem; }
.vc2-body p { font-size: .9rem; color: var(--t2); font-weight: 300; line-height: 1.7; }
.arch-hero { display: grid; grid-template-columns: 350px 1fr; gap: 5rem; align-items: start; }
.arch-portrait { position: relative; aspect-ratio: 3/4; background: linear-gradient(160deg, #24292D, #1B2024 40%, #1A1F23); overflow: hidden; border: 1px solid var(--border); }
.arch-portrait img { width: 100%; height: 100%; object-fit: cover; }
.arch-portrait .initials { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); font-family: var(--fd); font-size: 6rem; font-weight: 300; color: rgba(201,169,110,.06); letter-spacing: .3em; }
.arch-bio p { color: var(--t2); font-weight: 300; line-height: 1.9; margin-bottom: 1.5rem; font-size: 1.05rem; }
.arch-bio strong { color: var(--al); font-weight: 500; }
.achievements { display: grid; grid-template-columns: repeat(4, 1fr); gap: 2rem; margin-top: 4rem; }
.ach-card { background: var(--card2); border: 1px solid var(--border); padding: 2.5rem 2rem; text-align: center; transition: all .4s var(--e); }
.ach-card:hover { border-color: rgba(201,169,110,.3); transform: translateY(-3px); }
.ach-num { font-family: var(--fd); font-size: 3rem; font-weight: 300; color: var(--a); line-height: 1; margin-bottom: .75rem; }
.ach-label { font-size: .75rem; letter-spacing: .1em; text-transform: uppercase; color: var(--t3); line-height: 1.4; }
.arch-gallery { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; }
.ag-item { aspect-ratio: 1; overflow: hidden; position: relative; cursor: pointer; border: 1px solid var(--border); transition: all .4s var(--e); }
.ag-item:hover { border-color: rgba(201,169,110,.3); }
.ag-item img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s var(--e); }
.ag-item:hover img { transform: scale(1.1); }
.ag-item .agb { width: 100%; height: 100%; transition: transform .6s var(--e); }
.ag-item:hover .agb { transform: scale(1.1); }
.contact-layout { display: grid; grid-template-columns: 1fr 1.2fr; gap: 4rem; }
.c-info h3 { font-family: var(--fd); font-size: 1.8rem; font-weight: 300; margin-bottom: 2rem; }
.c-card { display: flex; align-items: flex-start; gap: 1.25rem; padding: 1.5rem; background: var(--card2); border: 1px solid var(--border); margin-bottom: 1.25rem; transition: all .3s var(--e); }
.c-card:hover { border-color: var(--ad); transform: translateX(5px); }
.c-card svg { width: 22px; height: 22px; stroke: var(--a); fill: none; stroke-width: 1.5; flex-shrink: 0; margin-top: 2px; }
.c-card .c-label { font-size: .75rem; letter-spacing: .1em; text-transform: uppercase; color: var(--t3); margin-bottom: .25rem; }
.c-card .c-value { font-size: 1.05rem; color: var(--t1); font-weight: 400; }
.c-card .c-value a { color: var(--al); transition: color .3s; }
.c-card .c-value a:hover { color: var(--a); }
.c-note { margin-top: 2rem; padding: 2rem; background: var(--card2); border-left: 3px solid var(--a); }
.c-note p { font-family: var(--fd); font-size: 1.2rem; font-style: italic; color: var(--al); line-height: 1.5; }
.c-form h3 { font-family: var(--fd); font-size: 1.8rem; font-weight: 300; margin-bottom: 2rem; }
.map-section { width: 100%; height: 400px; background: var(--card2); border-top: 1px solid var(--border); position: relative; overflow: hidden; }
.map-bg { width: 100%; height: 100%; background: linear-gradient(135deg, #24292D, #1B2024 30%, #1A1F23 60%, #161920); position: relative; }
.map-bg::before { content: ''; position: absolute; inset: 0; background: radial-gradient(circle at 50% 50%, rgba(201,169,110,.08), transparent 50%); }
.map-pin { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-100%); z-index: 2; }
.map-pin svg { width: 40px; height: 40px; stroke: var(--a); fill: rgba(201,169,110,.2); stroke-width: 1.5; filter: drop-shadow(0 4px 12px rgba(201,169,110,.3)); }
.map-label { position: absolute; top: calc(50% + 10px); left: 50%; transform: translateX(-50%); background: rgba(27,32,36,.8); backdrop-filter: blur(10px); padding: .5rem 1.25rem; border: 1px solid var(--border); font-family: var(--fd); font-size: 1rem; color: var(--al); white-space: nowrap; z-index: 2; }
.map-grid { position: absolute; inset: 0; background-image: linear-gradient(rgba(201,169,110,.03) 1px, transparent 1px), linear-gradient(90deg, rgba(201,169,110,.03) 1px, transparent 1px); background-size: 60px 60px; }
.wp-content { max-width: 800px; margin: 0 auto; padding: 4rem 3rem; }
.wp-content h1, .wp-content h2, .wp-content h3, .wp-content h4 { font-family: var(--fd); font-weight: 400; margin-bottom: 1rem; }
.wp-content h2 { font-size: 2rem; }
.wp-content h3 { font-size: 1.5rem; }
.wp-content p { color: var(--t2); line-height: 1.8; margin-bottom: 1.5rem; font-weight: 300; }
.wp-content a { color: var(--a); border-bottom: 1px solid transparent; transition: border-color .3s; }
.wp-content a:hover { border-bottom-color: var(--a); }
.wp-content ul, .wp-content ol { color: var(--t2); margin: 0 0 1.5rem 1.5rem; }
.wp-content li { margin-bottom: .5rem; }
.wp-content blockquote { border-left: 3px solid var(--a); padding: 1.5rem 2rem; margin: 2rem 0; background: var(--card2); }
.wp-content blockquote p { font-family: var(--fd); font-size: 1.2rem; color: var(--al); font-style: italic; margin-bottom: 0; }
.wp-content img { border-radius: 0; margin: 2rem 0; }
.error-404 { text-align: center; padding: 10rem 2rem; min-height: 70vh; display: flex; flex-direction: column; align-items: center; justify-content: center; }
.error-404 h1 { font-family: var(--fd); font-size: 8rem; color: var(--a); font-weight: 300; line-height: 1; margin-bottom: 1rem; }
.error-404 p { color: var(--t2); margin-bottom: 2rem; }
.comments-area { padding: 4rem 3rem; max-width: 800px; margin: 0 auto; }
.comment-list { list-style: none; }
.comment-body { background: var(--card2); border: 1px solid var(--border); padding: 2rem; margin-bottom: 1.5rem; }
.comment-body .fn { font-family: var(--fd); font-size: 1.1rem; color: var(--al); }
.comment-body .comment-meta { font-size: .8rem; color: var(--t3); margin-bottom: 1rem; }
.comment-body p { color: var(--t2); }
.master-intro { display: grid; grid-template-columns: auto 1fr; gap: 3rem; align-items: center; margin-bottom: 4rem; padding: 3rem; background: var(--card2); border: 1px solid var(--border); }
.master-avatar { width: 120px; height: 120px; border-radius: 50%; background: linear-gradient(135deg, #24292D, #1B2024); display: flex; align-items: center; justify-content: center; font-family: var(--fd); font-size: 2.5rem; color: rgba(201,169,110,.2); border: 1px solid var(--border); overflow: hidden; }
.master-avatar img { width: 100%; height: 100%; object-fit: cover; }
.master-text h3 { font-family: var(--fd); font-size: 1.6rem; font-weight: 400; margin-bottom: .75rem; color: var(--al); }
.master-text p { color: var(--t2); font-weight: 300; line-height: 1.8; }
.ft { background: var(--footer); padding: 4rem 3rem 2rem; border-top: 1px solid var(--border2); }
.ftt { display: flex; justify-content: space-between; align-items: flex-start; padding-bottom: 3rem; border-bottom: 1px solid var(--border2); margin-bottom: 2rem; }
.ftb { font-family: var(--fd); font-size: 1.4rem; font-weight: 300; letter-spacing: .3em; text-transform: uppercase; }
.ftb b { color: var(--a); font-weight: 600; }
.fl { display: flex; gap: 2rem; list-style: none; }
.fl li { list-style: none; }
.fl a { font-size: .8rem; letter-spacing: .1em; text-transform: uppercase; color: var(--t3); transition: color .3s; }
.fl a:hover { color: var(--a); }
.ftm { display: flex; justify-content: space-between; align-items: center; }
.ftm p { font-size: .8rem; color: var(--t3); }
.r { opacity: 0; transform: translateY(40px); transition: all .8s var(--e); }
.r.v { opacity: 1; transform: translateY(0); }
.rd1 { transition-delay: .1s; } .rd2 { transition-delay: .2s; } .rd3 { transition-delay: .3s; }
@media (max-width: 1024px) {
    .sec { padding: 5rem 2rem; } .nav { padding: 1.25rem 2rem; } .ag { grid-template-columns: 1fr; gap: 3rem; }
    .sg { grid-template-columns: repeat(2, 1fr); } .al { grid-template-columns: 250px 1fr; gap: 3rem; }
    .pg { grid-template-columns: 1fr; } .gg { grid-template-columns: repeat(3, 1fr); } .vs { grid-template-columns: repeat(2, 1fr); }
    .about-full { grid-template-columns: 1fr; } .vg2 { grid-template-columns: 1fr; } .masonry { grid-template-columns: repeat(3, 1fr); }
    .arch-hero { grid-template-columns: 250px 1fr; gap: 3rem; } .achievements { grid-template-columns: repeat(2, 1fr); }
    .arch-gallery { grid-template-columns: repeat(3, 1fr); } .proj-card { grid-template-columns: 1fr; }
    .proj-card:nth-child(even) { direction: ltr; } .proj-img { min-height: 250px; } .contact-layout { grid-template-columns: 1fr; }
}
@media (max-width: 1300px) {
    .nl { display: none; } .burger { display: flex; }
}
@media (max-width: 768px) {
    .sec { padding: 4rem 1.25rem; }
    .hero h1 { font-size: clamp(2rem, 8vw, 3.5rem); } .sg { grid-template-columns: 1fr; }
    .al { grid-template-columns: 1fr; } .cg { grid-template-columns: 1fr; } .vs { grid-template-columns: 1fr; }
    .gg { grid-template-columns: repeat(2, 1fr); } .as { grid-template-columns: repeat(3, 1fr); gap: 1rem; } .sn { font-size: 2rem; }
    .ftt { flex-direction: column; gap: 2rem; } .fl { flex-wrap: wrap; gap: 1rem; }
    .ftm { flex-direction: column; gap: 1rem; text-align: center; } .fr, .fr2 { grid-template-columns: 1fr; }
    .hcta { flex-direction: column; align-items: center; }
    .hd { width: 280px; height: 280px; } .hd::before { width: 220px; height: 220px; } .hd::after { width: 350px; height: 350px; }
    .phero { padding: 8rem 1.5rem 3rem; } .masonry { grid-template-columns: repeat(2, 1fr); } .arch-hero { grid-template-columns: 1fr; }
    .arch-gallery { grid-template-columns: repeat(2, 1fr); }
    .master-intro { grid-template-columns: 1fr; text-align: center; justify-items: center; }
    .specs { grid-template-columns: 1fr; } .map-section { height: 300px; } .wp-content { padding: 3rem 1.25rem; }
    .hscr { bottom: 0.75rem; z-index: 10; }
}
.lightbox-overlay { position: fixed; inset: 0; z-index: 9999; background: rgba(0,0,0,0); backdrop-filter: blur(0px); display: flex; align-items: center; justify-content: center; pointer-events: none; transition: all .35s var(--e); }
.lightbox-overlay.active { background: rgba(0,0,0,.88); backdrop-filter: blur(16px); pointer-events: all; }
.lightbox-content { position: relative; max-width: 90vw; max-height: 85vh; transform: scale(.9); opacity: 0; transition: all .35s var(--e); }
.lightbox-overlay.active .lightbox-content { transform: scale(1); opacity: 1; }
.lightbox-content img { max-width: 90vw; max-height: 85vh; width: 70vw; height: auto; object-fit: contain; display: block; box-shadow: 0 20px 80px rgba(0,0,0,.6); border: 1px solid var(--border); }
.lightbox-content .lightbox-gradient { width: 70vw; max-width: 800px; aspect-ratio: 16/10; border: 1px solid var(--border); box-shadow: 0 20px 80px rgba(0,0,0,.6); }
.lightbox-caption { position: absolute; bottom: -2.5rem; left: 0; right: 0; text-align: center; font-family: var(--fd); font-size: 1.1rem; color: var(--t2); font-weight: 300; opacity: 0; transition: opacity .3s .15s; }
.lightbox-overlay.active .lightbox-caption { opacity: 1; }
.lightbox-close { position: fixed; top: 1.5rem; right: 1.5rem; width: 48px; height: 48px; z-index: 10000; display: none; align-items: center; justify-content: center; background: rgba(27,32,36,.8); border: 1px solid var(--border); color: var(--t2); font-size: 1.5rem; cursor: pointer; transition: all .3s; padding: 0; }
.lightbox-overlay.active .lightbox-close { display: flex; }
.lightbox-close:hover { background: var(--a); color: var(--bg); border-color: var(--a); transform: none; box-shadow: none; }
.lightbox-nav { position: fixed; top: 50%; z-index: 10000; width: 48px; height: 48px; transform: translateY(-50%); display: none; align-items: center; justify-content: center; background: rgba(27,32,36,.8); border: 1px solid var(--border); color: var(--t2); font-size: 1.2rem; cursor: pointer; transition: all .3s; padding: 0; }
.lightbox-overlay.active .lightbox-nav { display: flex; }
.lightbox-nav:hover { background: var(--a); color: var(--bg); border-color: var(--a); transform: translateY(-50%); box-shadow: none; }
.lightbox-nav--prev { left: 1.5rem; } .lightbox-nav--next { right: 1.5rem; }
.lightbox-counter { position: fixed; bottom: 0.5rem; left: 50%; transform: translateX(-50%); font-size: .8rem; color: var(--t3); letter-spacing: .1em; z-index: 10000; display: none; }
.lightbox-overlay.active .lightbox-counter { display: block; }
body.lightbox-open { overflow: hidden; }
@media (max-width: 768px) { .lightbox-nav { width: 40px; height: 40px; } .lightbox-nav--prev { left: .75rem; } .lightbox-nav--next { right: .75rem; } .lightbox-close { top: 1rem; right: 1rem; } .lightbox-content .lightbox-gradient { width: 90vw; } }
@media (max-width: 480px) { .gg { grid-template-columns: repeat(2, 1fr); } .as { grid-template-columns: 1fr; } .achievements { grid-template-columns: 1fr; } }

/* ========================================
   СТРАНИЦА РАСЦЕНОК
   ======================================== */

/* --- Секция pricing --- */
.pricing-wrapper { max-width: 1200px; margin: 0 auto; padding: 4rem 1.5rem; }

/* --- Аккордеон --- */
.pricing-accordion { display: flex; flex-direction: column; gap: 1.5rem; margin-bottom: 4rem; }

.accordion-item { background: var(--card); border: 1px solid var(--border); border-radius: 8px; overflow: hidden; transition: all .3s var(--e); }
.accordion-item:hover { border-color: var(--border2); box-shadow: 0 4px 20px rgba(0,0,0,.15); }
.accordion-item.active { border-color: var(--a); background: var(--card2); }

/* Заголовок аккордеона */
.accordion-header { display: flex; align-items: center; justify-content: space-between; padding: 1.5rem 2rem; cursor: pointer; gap: 1rem; transition: all .3s var(--e); }
.accordion-item:hover .accordion-header { background: rgba(201,169,110,.05); }
.accordion-item.active .accordion-header { background: rgba(201,169,110,.08); }

.accordion-title { display: flex; align-items: center; gap: 1.25rem; flex: 1; }

.accordion-icon { display: flex; align-items: center; justify-content: center; width: 50px; height: 50px; background: var(--bg2); border: 1px solid var(--border); border-radius: 50%; font-family: var(--fd); font-size: 1.1rem; font-weight: 600; color: var(--a); flex-shrink: 0; transition: all .3s var(--e); }
.accordion-item:hover .accordion-icon { border-color: var(--a); background: rgba(201,169,110,.1); }

.accordion-title h3 { margin: 0; font-size: 1.35rem; font-weight: 500; color: var(--t1); transition: color .3s var(--e); }
.accordion-item.active .accordion-title h3 { color: var(--a); }

/* Цена в заголовке */
.accordion-price { display: flex; align-items: baseline; gap: .5rem; padding: .75rem 1.5rem; background: var(--bg2); border: 1px solid var(--border); border-radius: 6px; transition: all .3s var(--e); }
.accordion-item:hover .accordion-price, .accordion-item.active .accordion-price { border-color: var(--a); background: rgba(201,169,110,.05); }

.price-label { font-size: .85rem; color: var(--t3); text-transform: uppercase; letter-spacing: .05em; }
.price-value { font-size: 1.5rem; font-weight: 600; color: var(--a); font-family: var(--fd); }

/* Кнопка toggle */
.accordion-toggle { width: 40px; height: 40px; display: flex; align-items: center; justify-content: center; border-radius: 50%; background: var(--bg2); border: 1px solid var(--border); transition: all .3s var(--e); flex-shrink: 0; }
.accordion-item:hover .accordion-toggle { border-color: var(--a); }

.toggle-icon { width: 14px; height: 14px; position: relative; transition: transform .3s var(--e); }
.toggle-icon::before, .toggle-icon::after { content: ''; position: absolute; background: var(--a); border-radius: 2px; }
.toggle-icon::before { width: 100%; height: 2px; top: 50%; left: 0; transform: translateY(-50%); }
.toggle-icon::after { width: 2px; height: 100%; left: 50%; top: 0; transform: translateX(-50%); transition: opacity .3s var(--e); }
.accordion-item.active .toggle-icon { transform: rotate(180deg); }
.accordion-item.active .toggle-icon::after { opacity: 0; }

/* Контент аккордеона */
.accordion-content { max-height: 0; overflow: hidden; transition: max-height .4s var(--e), opacity .3s var(--e); opacity: 0; }
.accordion-item.active .accordion-content { max-height: 2000px; opacity: 1; }

.accordion-inner { padding: 0 2rem 2rem 2rem; }

.accordion-desc { margin: 0 0 1.5rem 0; font-size: 1.05rem; color: var(--t2); line-height: 1.7; padding-bottom: 1.5rem; border-bottom: 1px solid var(--border); }

/* Список услуг */
.pricing-list { list-style: none; padding: 0; margin: 0 0 2rem 0; display: flex; flex-direction: column; gap: 1rem; }
.pricing-list li { display: flex; align-items: flex-start; gap: 1rem; padding: 1rem; background: var(--bg2); border-radius: 6px; border: 1px solid transparent; transition: all .3s var(--e); }
.pricing-list li:hover { border-color: var(--border2); background: rgba(201,169,110,.03); }

.check-icon { display: inline-flex; align-items: center; justify-content: center; width: 24px; height: 24px; background: rgba(201,169,110,.15); color: var(--a); border-radius: 50%; font-weight: 600; font-size: .85rem; flex-shrink: 0; margin-top: .1rem; }
.pricing-list li span:last-child { color: var(--t2); font-size: 1rem; line-height: 1.6; }

/* Таблица цен */
.pricing-table { display: flex; flex-direction: column; gap: 1rem; margin-bottom: 2rem; }
.pricing-row { display: flex; align-items: center; justify-content: space-between; padding: 1.25rem 1.5rem; background: var(--bg2); border: 1px solid var(--border); border-radius: 6px; transition: all .3s var(--e); }
.pricing-row:hover { border-color: var(--border2); background: rgba(201,169,110,.03); }
.service-name { font-size: 1rem; color: var(--t2); font-weight: 400; }
.service-price { font-size: 1.2rem; font-weight: 600; color: var(--a); font-family: var(--fd); }

/* Footer аккордеона */
.accordion-footer { display: flex; align-items: center; justify-content: space-between; gap: 2rem; flex-wrap: wrap; }
.info-note { font-size: .9rem; color: var(--t3); font-style: italic; }

/* --- Информационные карточки --- */
.pricing-info { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 2rem; margin-bottom: 4rem; }
.info-card { background: var(--card); border: 1px solid var(--border); border-radius: 8px; padding: 2rem; transition: all .3s var(--e); }
.info-card:hover { border-color: var(--border2); box-shadow: 0 4px 20px rgba(0,0,0,.15); transform: translateY(-4px); }
.info-card h4 { margin: 0 0 1rem 0; font-size: 1.25rem; font-weight: 500; color: var(--t1); }
.info-card p { margin: 0; font-size: 1rem; color: var(--t2); line-height: 1.7; }

/* --- CTA секция --- */
.pricing-cta { text-align: center; padding: 4rem 2rem; background: var(--card); border: 1px solid var(--border); border-radius: 12px; position: relative; overflow: hidden; }
.pricing-cta::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: linear-gradient(90deg, transparent, var(--a), transparent); }
.pricing-cta h2 { margin: 0 0 1rem 0; font-size: 2rem; font-weight: 400; color: var(--t1); }
.pricing-cta h2 em { font-family: var(--fd); color: var(--a); font-style: italic; }
.pricing-cta > p { margin: 0 0 2rem 0; font-size: 1.15rem; color: var(--t2); max-width: 600px; margin-left: auto; margin-right: auto; }
.cta-buttons { display: flex; align-items: center; justify-content: center; gap: 1.5rem; flex-wrap: wrap; }

/* --- Адаптивность страницы расценок --- */
@media (max-width: 1024px) {
    .pricing-wrapper { padding: 3rem 1.25rem; }
    .accordion-header { padding: 1.25rem 1.5rem; flex-wrap: wrap; }
    .accordion-title { width: 100%; margin-bottom: .5rem; }
    .accordion-price { width: auto; }
    .pricing-info { grid-template-columns: 1fr; gap: 1.5rem; }
    .pricing-cta h2 { font-size: 1.75rem; }
}

@media (max-width: 768px) {
    .pricing-wrapper { padding: 2rem 1rem; }
    .accordion-header { padding: 1rem; gap: .75rem; }
    .accordion-icon { width: 42px; height: 42px; font-size: .95rem; }
    .accordion-title h3 { font-size: 1.15rem; }
    .accordion-price { padding: .5rem 1rem; font-size: .9rem; }
    .price-value { font-size: 1.25rem; }
    .accordion-toggle { width: 36px; height: 36px; }
    .accordion-inner { padding: 0 1rem 1.5rem 1rem; }
    .accordion-desc { font-size: 1rem; padding-bottom: 1rem; }
    .pricing-list li { padding: .875rem; gap: .75rem; }
    .pricing-row { flex-direction: column; align-items: flex-start; gap: .5rem; padding: 1rem; }
    .service-price { font-size: 1.1rem; }
    .info-card { padding: 1.5rem; }
    .info-card h4 { font-size: 1.1rem; }
    .info-card p { font-size: .95rem; }
    .pricing-cta { padding: 2.5rem 1.5rem; }
    .pricing-cta h2 { font-size: 1.5rem; }
    .pricing-cta > p { font-size: 1rem; }
    .cta-buttons { flex-direction: column; width: 100%; }
    .cta-buttons .btn { width: 100%; justify-content: center; }
    .accordion-footer { flex-direction: column; align-items: flex-start; gap: 1rem; }
    .accordion-footer .btn { width: 100%; justify-content: center; }
}

/* --- Анимации страницы расценок --- */
@keyframes fadeInUp {
    from { opacity: 0; transform: translateY(20px); }
    to { opacity: 1; transform: translateY(0); }
}

.accordion-item { animation: fadeInUp .5s var(--e) forwards; }
.accordion-item:nth-child(1) { animation-delay: .1s; }
.accordion-item:nth-child(2) { animation-delay: .2s; }
.accordion-item:nth-child(3) { animation-delay: .3s; }
.accordion-item:nth-child(4) { animation-delay: .4s; }
.accordion-item:nth-child(5) { animation-delay: .5s; }

.info-card { animation: fadeInUp .5s var(--e) forwards; opacity: 0; }
.info-card:nth-child(1) { animation-delay: .6s; }
.info-card:nth-child(2) { animation-delay: .7s; }
.info-card:nth-child(3) { animation-delay: .8s; }
.st a, .pnf h3 a, .proj-body h3 a, .vo h3 a { color: inherit; position: relative; transition: color .3s; }
.st a::after, .pnf h3 a::after, .proj-body h3 a::after, .vo h3 a::after { content: ''; position: absolute; bottom: -4px; left: 0; width: 0; height: 1px; background: var(--a); transition: width .4s var(--e); }
.st a:hover, .pnf h3 a:hover, .proj-body h3 a:hover, .vo h3 a:hover { color: var(--a); }
.st a:hover::after, .pnf h3 a:hover::after, .proj-body h3 a:hover::after, .vo h3 a:hover::after { width: 100%; }

/* Contact person avatar */
.contact-person-hero { display: flex; align-items: center; gap: 1.25rem; justify-content: center; }

/* Home team */
.home-team { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; }
.home-member { background: var(--card2); border: 1px solid var(--border); padding: 2.5rem; text-align: center; transition: all .4s var(--e); }
.home-member:hover { border-color: rgba(201,169,110,.3); transform: translateY(-3px); }
.home-member-photo { width: 100px; height: 100px; border-radius: 50%; overflow: hidden; margin: 0 auto 1.5rem; border: 2px solid var(--border); }
.home-member-photo img { width: 100%; height: 100%; object-fit: cover; }
.home-member-initials { width: 100%; height: 100%; background: linear-gradient(135deg, var(--card2), #1B2024); display: flex; align-items: center; justify-content: center; font-family: var(--fd); font-size: 2rem; color: rgba(201,169,110,.25); }
.home-member h3 { font-family: var(--fd); font-size: 1.2rem; font-weight: 400; margin-bottom: .25rem; color: var(--t1); }
.home-member-role { font-size: .7rem; letter-spacing: .12em; text-transform: uppercase; color: var(--a); margin-bottom: 1rem; }
.home-member p { font-size: .85rem; color: var(--t2); font-weight: 300; line-height: 1.6; }
.contact-avatar-wrap { position: relative; width: 72px; height: 72px; flex-shrink: 0; }
.contact-avatar-img { width: 100%; height: 100%; border-radius: 50%; object-fit: cover; border: 2px solid var(--border); }
.contact-avatar-initials { width: 100%; height: 100%; border-radius: 50%; background: linear-gradient(135deg, var(--card2), #1B2024); border: 2px solid var(--border); display: flex; align-items: center; justify-content: center; font-family: var(--fd); font-size: 1.8rem; color: rgba(201,169,110,.3); }
.contact-avatar-dot { position: absolute; bottom: 3px; right: 3px; width: 14px; height: 14px; background: #4ade80; border-radius: 50%; border: 3px solid var(--bg2); }
.contact-person-info { text-align: left; }
.contact-person-name { font-family: var(--fd); font-size: 1.2rem; color: var(--t1); margin-bottom: .15rem; }
.contact-person-role { font-size: .75rem; letter-spacing: .1em; text-transform: uppercase; color: var(--a); margin-bottom: .35rem; }
.contact-person-note { font-size: .85rem; color: var(--t3); font-weight: 300; }
@media (max-width: 600px) { .contact-person-hero { flex-direction: column; text-align: center; } .contact-person-info { text-align: center; } .home-team { grid-template-columns: 1fr; } }
@media (max-width: 900px) { .home-team { grid-template-columns: repeat(2, 1fr); } }