/*
Theme Name: dds_ctbuh2017.com
Author: Алексей Соколов
Description: Информационно-аналитический портал об инвестиционной недвижимости и рынке жилой и коммерческой аналитики. Тёмная финансовая эстетика с элементами спортивной аналитики.
Version: 1.1
Text Domain: realytics
*/

/* ============ Шрифты ============ */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@500;600;700;800&family=IBM+Plex+Sans:wght@300;400;500;600&family=JetBrains+Mono:wght@400;500;700&display=swap');

/* ============ Переменные ============ */
:root{
    --bg:#111217;
    --panel:#1E1E24;
    --bronze:#8A7B6B;
    --gold:#C6A43F;
    --steel:#5D6D7A;
    --text:#E6E6E6;
    --head:#FFFFFF;
    --muted:#9A9A9A;
    --pos:#2ECC71;
    --mid:#F39C12;
    --neg:#E74C3C;
    --shell:min(92%,1180px);
    --serif:'Playfair Display',Georgia,serif;
    --sans:'IBM Plex Sans',-apple-system,sans-serif;
    --mono:'JetBrains Mono','Courier New',monospace;
}

/* ============ Базовый сброс ============ */
*{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;}
body{
    margin:0;
    background:var(--bg);
    color:var(--text);
    font-family:var(--sans);
    font-size:17px;
    line-height:1.7;
    font-weight:400;
    overflow-x:hidden;
}
img{max-width:100%;height:auto;}
a{color:var(--gold);text-decoration:none;}
a:hover{text-decoration:underline;}

h1,h2,h3,h4,h5,h6{
    font-family:var(--serif);
    color:var(--head);
    line-height:1.25;
    letter-spacing:.4px;
    margin:0 0 .6em;
    font-weight:700;
}
h1{font-size:2.3rem;}
h2{font-size:1.8rem;}
h3{font-size:1.35rem;}
p{margin:0 0 1.1em;}

/* Контейнер ширины — единый источник */
.shell{
    width:var(--shell);
    margin-inline:auto;
}

/* ============ Кнопки ============ */
.btn{
    display:inline-block;
    font-family:var(--sans);
    font-weight:600;
    font-size:.95rem;
    letter-spacing:.3px;
    padding:.7em 1.5em;
    background:var(--gold);
    color:#15140f;
    border:1px solid var(--gold);
    cursor:pointer;
    clip-path:polygon(0 0,100% 0,100% 100%,18px 100%,0 calc(100% - 18px));
    transition:background .25s,color .25s;
}
.btn:hover{
    background:var(--bg);
    color:var(--gold);
    text-decoration:none;
}

/* Кнопка-фильтр категории */
.cat-link{
    display:inline-block;
    font-family:var(--mono);
    font-size:.82rem;
    text-transform:uppercase;
    letter-spacing:.6px;
    color:var(--steel);
    padding:.2em 0;
    border-bottom:1px solid var(--steel);
    transition:color .2s,filter .25s;
}
.cat-link::after{content:'';margin-left:.3em;}
.cat-link:hover{
    color:var(--gold);
    text-decoration:none;
    filter:blur(.4px);
}
.cat-link:hover::after{content:'\2192';}

/* Круглая кнопка "К прогнозу" */
.go-forecast{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:44px;height:44px;
    border-radius:50%;
    background:var(--steel);
    color:var(--head);
    flex:0 0 auto;
    transition:transform .25s,background .25s;
}
.go-forecast svg{width:20px;height:20px;display:block;}
.go-forecast:hover{
    background:var(--gold);
    text-decoration:none;
}
.go-forecast:hover svg{transform:rotate(15deg);}

/* ============ Шапка ============ */
.site-header{
    border-bottom:1px solid var(--bronze);
    background:#0d0e12;
}
.header-inner{
    display:flex;
    align-items:center;
    gap:24px;
    padding:22px 0;
    flex-wrap:wrap;
}
.brand{
    display:flex;
    align-items:center;
    gap:16px;
    min-width:0;
}
.brand-logo,.brand-logo svg{
    width:54px;height:54px;
    display:block;
    flex:0 0 auto;
}
.brand-text{min-width:0;}
.brand-title{
    font-family:var(--serif);
    font-size:1.15rem;
    font-weight:700;
    color:var(--head);
    line-height:1.3;
    display:block;
}
.brand-title a{color:var(--head);}
.brand-title a:hover{text-decoration:none;color:var(--gold);}
.brand-desc{
    font-size:.82rem;
    color:var(--muted);
    margin-top:4px;
    line-height:1.5;
}
.main-nav{margin-left:auto;}
.nav-toggle{
    display:none;
    background:none;
    border:1px solid var(--bronze);
    color:var(--text);
    padding:.5em .8em;
    cursor:pointer;
    font-size:.9rem;
}
.menu{
    list-style:none;
    margin:0;padding:0;
    display:flex;
    gap:6px;
    flex-wrap:wrap;
}
.menu a{
    display:block;
    font-family:var(--mono);
    font-size:.84rem;
    text-transform:uppercase;
    letter-spacing:.5px;
    color:var(--text);
    padding:.5em .9em;
    border:1px solid transparent;
    transition:color .2s,border-color .2s;
}
.menu a:hover,.menu .current-menu-item>a{
    color:var(--gold);
    border-color:var(--bronze);
    text-decoration:none;
}

/* ============ Основной макет ============ */
.site-main{padding:38px 0 56px;}

.layout-with-sidebar{
    display:grid;
    grid-template-columns:minmax(0,67fr) minmax(0,27fr);
    gap:42px;
    align-items:start;
}
.layout-single{
    display:block;
}
.layout-single .content-area,
.layout-narrow{
    width:85%;
    margin-left:auto;
    margin-right:auto;
}
.content-area{min-width:0;}

/* ============ Сайдбар ============ */
.sidebar{
    min-width:0;
    background:var(--panel);
    border:1px solid var(--bronze);
    padding:24px 22px;
}
.sidebar .widget{margin-bottom:30px;}
.sidebar .widget:last-child{margin-bottom:0;}
.sidebar .widget-title{
    font-size:1.05rem;
    color:var(--head);
    padding-bottom:8px;
    border-bottom:1px solid var(--bronze);
    margin-bottom:14px;
}
.sidebar a{color:var(--text);}
.sidebar a:hover{color:var(--gold);}
.sidebar ul{list-style:none;margin:0;padding:0;}
.sidebar li{
    padding:7px 0;
    border-bottom:1px solid rgba(138,123,107,.22);
    font-size:.92rem;
}
.sidebar li:last-child{border-bottom:none;}
.sidebar .post-date{
    display:block;
    font-family:var(--mono);
    font-size:.74rem;
    color:var(--muted);
    margin-top:2px;
}

/* ============ Хлебные крошки ============ */
.breadcrumbs{
    font-family:var(--mono);
    font-size:.78rem;
    color:var(--muted);
    margin:0 0 24px;
    letter-spacing:.3px;
}
.breadcrumbs a{color:var(--steel);}
.breadcrumbs a:hover{color:var(--gold);}
.breadcrumbs .sep{margin:0 .35em;color:var(--bronze);}

/* ============ Карточки записей ============ */
.card{
    display:flex;
    flex-direction:column;
    background:var(--panel);
    border:1px solid var(--bronze);
    overflow:hidden;
    margin-bottom:26px;
}
.card-thumb-wrap{
    flex:0 0 280px;
    position:relative;
    overflow:hidden;
    min-height:200px;
}
.card-thumb-wrap a{
    display:block;
    position:absolute;
    top:0;left:0;right:0;bottom:0;
}
.card-thumb-wrap img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
}
.card-thumb-ph{
    position:absolute;
    inset:0;
    display:flex;
    align-items:center;
    justify-content:center;
    background:linear-gradient(135deg,#22232b,#15161c);
    color:var(--bronze);
}
.card-thumb-ph svg{width:48px;height:48px;}
.card-body{
    flex:1;
    min-width:0;
    padding:22px 24px;
    display:flex;
    flex-direction:column;
}
.card-cats{margin-bottom:10px;}
.card-title{
    font-size:1.3rem;
    margin-bottom:10px;
}
.card-title a{color:var(--head);}
.card-title a:hover{color:var(--gold);text-decoration:none;}
.card-excerpt{color:var(--text);font-size:.95rem;}
.card-excerpt p{margin:0 0 .5em;background:none;}
.card-meta{
    font-family:var(--mono);
    font-size:.74rem;
    color:var(--muted);
    margin-top:auto;
    padding-top:14px;
    display:flex;
    align-items:center;
    gap:14px;
    flex-wrap:wrap;
}
.card-foot{
    display:flex;
    align-items:center;
    gap:16px;
    margin-top:16px;
}

/* Шкала вероятности */
.prob-scale{
    display:flex;
    align-items:center;
    gap:10px;
    margin-bottom:12px;
}
.prob-label{
    font-family:var(--mono);
    font-size:.66rem;
    text-transform:uppercase;
    letter-spacing:.5px;
    color:var(--muted);
    flex:0 0 auto;
}
.prob-track{
    flex:1;
    min-width:0;
    height:7px;
    background:#2a2b33;
    border:1px solid rgba(138,123,107,.4);
    overflow:hidden;
}
.prob-fill{
    height:100%;
    background:linear-gradient(90deg,var(--neg),var(--mid),var(--pos));
    transition:width 1.1s ease;
}
.prob-value{
    font-family:var(--mono);
    font-size:.78rem;
    font-weight:700;
    color:var(--gold);
    flex:0 0 auto;
}

/* Список карточек на странице блога — вертикальные/горизонтальные */
.cards-list .card{flex-direction:row;}
.cards-grid{
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
    gap:26px;
}
.cards-grid .card{margin-bottom:0;}
.cards-grid .card-thumb-wrap{
    flex:none;
    position:static;
    min-height:0;
}
.cards-grid .card-thumb-wrap a{position:static;}
.cards-grid .card-thumb-wrap img{
    height:auto;
    aspect-ratio:16/9;
}
.cards-grid .card-thumb-ph{
    position:relative;
    aspect-ratio:16/9;
}

/* ============ Контент записи/страницы ============ */
.entry{
    background:var(--panel);
    border:1px solid var(--bronze);
    padding:32px 36px;
}
.entry-header{margin-bottom:22px;}
.entry-title{font-size:2rem;margin-bottom:10px;}
.entry-meta{
    font-family:var(--mono);
    font-size:.76rem;
    color:var(--muted);
    display:flex;
    gap:16px;
    flex-wrap:wrap;
}
.entry-thumb{margin:0 0 24px;}
.entry-thumb img{width:100%;display:block;}
.entry-content{min-width:0;}
.entry-content p{margin:0 0 1.2em;}
.entry-content img{display:block;margin:18px 0;}
.entry-content h2,.entry-content h3{margin-top:1.4em;}
.entry-content a{text-decoration:underline;}
.entry-content blockquote{
    border-left:3px solid var(--gold);
    margin:1.4em 0;
    padding:.4em 0 .4em 22px;
    color:var(--muted);
    font-style:italic;
}
.entry-content ul,.entry-content ol{padding-left:1.4em;}
.entry-content li{margin-bottom:.4em;}
.entry-content code{
    font-family:var(--mono);
    background:#0d0e12;
    padding:.1em .4em;
    font-size:.88em;
    color:var(--gold);
}
.entry-content pre{
    background:#0d0e12;
    border:1px solid var(--bronze);
    padding:16px;
    overflow:auto;
    font-family:var(--mono);
    font-size:.85rem;
}

/* Таблицы */
table{
    width:100%;
    border-collapse:collapse;
    margin:1.4em 0;
}
table,th,td{border:1px solid var(--bronze);}
th,td{padding:10px 12px;text-align:left;}
th{
    background:#26272f;
    color:var(--head);
    font-family:var(--mono);
    font-size:.82rem;
    text-transform:uppercase;
    letter-spacing:.4px;
}

/* ============ Главная ============ */
.section{margin-bottom:54px;}
.section:last-child{margin-bottom:0;}
.section-head{
    margin-bottom:26px;
    border-bottom:1px solid var(--bronze);
    padding-bottom:12px;
}
.section-kicker{
    font-family:var(--mono);
    font-size:.74rem;
    text-transform:uppercase;
    letter-spacing:1.4px;
    color:var(--gold);
    display:block;
    margin-bottom:6px;
}
.section-title{font-size:1.9rem;margin:0;}

.feature-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
    gap:24px;
}
.feature{
    background:var(--panel);
    border:1px solid var(--bronze);
    padding:24px 22px;
    min-width:0;
}
.feature-num{
    font-family:var(--mono);
    font-size:2.4rem;
    font-weight:700;
    color:var(--gold);
    line-height:1;
    display:block;
    margin-bottom:10px;
}
.feature h3{font-size:1.15rem;margin-bottom:8px;}
.feature p{font-size:.92rem;color:var(--text);margin:0;}

.steps{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
    gap:22px;
    counter-reset:step;
}
.step{
    background:var(--panel);
    border:1px solid var(--bronze);
    border-top:3px solid var(--gold);
    padding:22px;
    min-width:0;
    position:relative;
}
.step::before{
    counter-increment:step;
    content:counter(step);
    font-family:var(--mono);
    font-size:1rem;
    font-weight:700;
    color:#15140f;
    background:var(--gold);
    width:30px;height:30px;
    display:flex;
    align-items:center;
    justify-content:center;
    margin-bottom:12px;
}
.step h3{font-size:1.1rem;}
.step p{font-size:.9rem;margin:0;}

.metric-band{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
    gap:1px;
    background:var(--bronze);
    border:1px solid var(--bronze);
}
.metric{
    background:var(--panel);
    padding:24px 20px;
    text-align:center;
    min-width:0;
}
.metric-value{
    font-family:var(--mono);
    font-size:2.1rem;
    font-weight:700;
    display:block;
    line-height:1.1;
}
.metric-value.pos{color:var(--pos);}
.metric-value.mid{color:var(--mid);}
.metric-value.neg{color:var(--neg);}
.metric-value.gold{color:var(--gold);}
.metric-label{
    font-size:.84rem;
    color:var(--muted);
    margin-top:6px;
    display:block;
}

.hero{
    background:linear-gradient(135deg,#181922,#0d0e12);
    border:1px solid var(--bronze);
    padding:46px 40px;
    margin-bottom:54px;
}
.hero h1{font-size:2.5rem;margin-bottom:14px;}
.hero p{
    color:var(--text);
    font-size:1.05rem;
    max-width:64ch;
}
.hero-actions{margin-top:22px;display:flex;gap:16px;flex-wrap:wrap;}

.intro-block{
    background:var(--panel);
    border:1px solid var(--bronze);
    border-left:3px solid var(--steel);
    padding:26px 28px;
}

/* ============ Пагинация ============ */
.pagination{
    margin-top:36px;
    display:flex;
    justify-content:center;
}
.pagination .page-numbers{
    list-style:none;
    margin:0;padding:0;
    display:flex;
    gap:6px;
    flex-wrap:wrap;
}
.pagination .page-numbers li a,
.pagination .page-numbers li span{
    display:block;
    font-family:var(--mono);
    font-size:.86rem;
    padding:.5em .85em;
    border:1px solid var(--bronze);
    color:var(--text);
    background:var(--panel);
}
.pagination .page-numbers li a:hover{
    color:var(--gold);
    text-decoration:none;
    border-color:var(--gold);
}
.pagination .page-numbers li .current{
    background:var(--gold);
    color:#15140f;
    border-color:var(--gold);
}

/* ============ Комментарии ============ */
.comments-area{
    margin-top:36px;
    background:var(--panel);
    border:1px solid var(--bronze);
    padding:28px 32px;
}
.comments-title{font-size:1.4rem;margin-bottom:18px;}
.comment-list{list-style:none;margin:0;padding:0;}
.comment-list ul.children{list-style:none;margin:0;padding-left:26px;}
.comment-body{
    padding:16px 0;
    border-bottom:1px solid rgba(138,123,107,.25);
}
.comment-author{font-weight:600;color:var(--head);}
.comment-meta{
    font-family:var(--mono);
    font-size:.72rem;
    color:var(--muted);
    margin-bottom:6px;
}
.comment-respond{margin-top:24px;}
.comment-form input[type=text],
.comment-form input[type=email],
.comment-form input[type=url],
.comment-form textarea{
    width:100%;
    background:#0d0e12;
    border:1px solid var(--bronze);
    color:var(--text);
    padding:10px 12px;
    font-family:var(--sans);
    font-size:.95rem;
    margin-bottom:14px;
}
.comment-form textarea{min-height:120px;}
.comment-form label{
    display:block;
    font-size:.85rem;
    color:var(--muted);
    margin-bottom:4px;
}

/* ============ Форма поиска ============ */
.search-form{
    display:flex;
    gap:8px;
}
.search-form .search-field{
    flex:1;
    min-width:0;
    background:#0d0e12;
    border:1px solid var(--bronze);
    color:var(--text);
    padding:.6em .8em;
    font-family:var(--sans);
    font-size:.95rem;
}
.search-form .search-submit{
    flex:0 0 auto;
}

/* ============ 404 ============ */
.error-404{
    background:var(--panel);
    border:1px solid var(--bronze);
    padding:46px 40px;
    text-align:center;
}
.error-404 .code{
    font-family:var(--mono);
    font-size:4.5rem;
    font-weight:700;
    color:var(--gold);
    line-height:1;
}
.error-404 .search-form{
    max-width:420px;
    margin-left:auto;
    margin-right:auto;
    margin-top:24px;
}

/* ============ Подвал ============ */
.site-footer{
    border-top:1px solid var(--bronze);
    background:#0d0e12;
}
/* Бегущая строка котировок */
.ticker{
    background:var(--panel);
    border-bottom:1px solid var(--bronze);
    overflow:hidden;
    white-space:nowrap;
}
.ticker-track{
    display:inline-flex;
    gap:42px;
    padding:10px 0;
    animation:ticker-run 32s linear infinite;
}
.ticker-item{
    font-family:var(--mono);
    font-size:.8rem;
    color:var(--muted);
}
.ticker-item b{color:var(--gold);}
.ticker-item .up{color:var(--pos);}
.ticker-item .down{color:var(--neg);}
@keyframes ticker-run{
    from{transform:translateX(0);}
    to{transform:translateX(-50%);}
}

.footer-cols{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:36px;
    padding:42px 0 30px;
}
.footer-col{min-width:0;}
.footer-col .widget-title{
    font-family:var(--serif);
    font-size:1.1rem;
    color:var(--head);
    margin-bottom:14px;
    padding-bottom:8px;
    border-bottom:1px solid var(--bronze);
}
.footer-col,
.footer-col p,
.footer-col li{color:#c4c4cc;}
.footer-col .widget{font-size:.92rem;}
.footer-col ul{list-style:none;margin:0;padding:0;}
.footer-col li{
    padding:6px 0;
    border-bottom:1px solid rgba(138,123,107,.2);
}
.footer-col li:last-child{border-bottom:none;}
.footer-col a{color:#c4c4cc;}
.footer-col a:hover{color:var(--gold);}
.footer-col .post-date{
    display:block;
    font-family:var(--mono);
    font-size:.72rem;
    color:var(--muted);
}
.footer-contacts a{display:inline-block;}
.footer-bottom{
    border-top:1px solid var(--bronze);
    padding:18px 0;
    font-family:var(--mono);
    font-size:.78rem;
    color:var(--muted);
    text-align:center;
}

/* ============ Cookie-баннер ============ */
.cookie-banner[hidden]{display:none !important;}
.cookie-banner{
    position:fixed;
    left:0;right:0;bottom:0;
    z-index:90;
    background:#0d0e12;
    border-top:1px solid var(--gold);
    padding:16px 0;
}
.cookie-inner{
    display:flex;
    align-items:center;
    gap:20px;
    flex-wrap:wrap;
}
.cookie-text{
    flex:1;
    min-width:240px;
    font-size:.86rem;
    color:var(--muted);
    margin:0;
}
.cookie-text a{color:var(--gold);}

/* ============ Адаптив ============ */
@media (max-width:960px){
    .layout-with-sidebar{
        grid-template-columns:1fr;
        gap:34px;
    }
    .layout-single .content-area,
    .layout-narrow,
    .hero,
    .error-404{width:100%;}
    h1{font-size:2rem;}
    .hero h1{font-size:2rem;}
}

@media (max-width:600px){
    body{font-size:16px;}
    .header-inner{padding:16px 0;}
    .main-nav{margin-left:0;width:100%;}
    .nav-toggle{display:block;}
    .menu{
        display:none;
        flex-direction:column;
        gap:0;
        margin-top:12px;
        border:1px solid var(--bronze);
    }
    .menu.is-open{display:flex;}
    .menu li{border-bottom:1px solid rgba(138,123,107,.25);}
    .menu li:last-child{border-bottom:none;}

    .cards-list .card{flex-direction:column;}
    .card-thumb-wrap{
        flex:none;
        width:100%;
        position:static;
        min-height:0;
    }
    .card-thumb-wrap a{position:static;}
    .card-thumb-wrap img{
        width:100%;
        height:auto;
        aspect-ratio:16/9;
    }
    .card-thumb-ph{
        position:relative;
        aspect-ratio:16/9;
    }
    .footer-cols{grid-template-columns:1fr;gap:28px;}
    .entry{padding:24px 20px;}
    .hero{padding:32px 22px;}
    .comments-area{padding:22px 18px;}

    /* Шкала вероятности — вертикальный индикатор слева от заголовка */
    .prob-scale{
        flex-direction:column;
        align-items:stretch;
        gap:6px;
    }
    .card-title-row{
        display:flex;
        gap:12px;
        align-items:stretch;
    }
    .card-title-row .prob-track{
        width:7px;
        height:auto;
        align-self:stretch;
        flex:0 0 7px;
    }
    .card-title-row .prob-fill{
        width:100%;
        background:linear-gradient(180deg,var(--pos),var(--mid),var(--neg));
    }
}
