/* ==========================================================================
   Психоаналітик Ольга Бальмен — static rebuild
   Self-contained: system fonts, local CSS/images, zero JS.
   Palette: deep blue #1c3a63 + warm red #b23a2f on warm off-white.
   ========================================================================== */

:root{
  --blue:#1c3a63;
  --blue-2:#2b5088;
  --red:#b23a2f;
  --red-2:#953026;
  --ink:#2a3340;
  --muted:#5d6572;
  --bg:#fbfaf7;
  --soft:#f3efe8;
  --line:#e7e1d6;
  --white:#fff;
  --container:1080px;
  --serif:Georgia,"Times New Roman","PT Serif",serif;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--bg);color:var(--ink);
  font-family:"Segoe UI",Roboto,"Helvetica Neue",Arial,system-ui,sans-serif;
  line-height:1.7;-webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;height:auto}
a{color:var(--red);text-decoration:none}
a:hover{color:var(--red-2)}
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:24px}
h1,h2,h3{font-family:var(--serif);color:var(--blue);font-weight:700;line-height:1.25}

/* ---------- Header ---------------------------------------------------- */
.site-header{background:var(--bg);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;padding-block:16px}
.logo img{height:38px;width:auto}
.nav-toggle{display:none}.nav-toggle-label{display:none}
.main-nav ul{list-style:none;margin:0;padding:0;display:flex;gap:30px;align-items:center}
.main-nav a{color:var(--blue);font-size:1rem;font-family:var(--serif)}
.main-nav a:hover,.main-nav a[aria-current="page"]{color:var(--red)}
.main-nav a[aria-current="page"]{border-bottom:1px solid var(--red)}
.social-fb{color:var(--blue);font-size:.9rem}

/* ---------- Buttons --------------------------------------------------- */
.btn{display:inline-block;padding:13px 32px;border-radius:2px;font-size:1rem;font-family:var(--serif);
  border:1px solid var(--red);cursor:pointer;transition:.15s;letter-spacing:.01em}
.btn-red{background:var(--red);color:#fff}
.btn-red:hover{background:var(--red-2);color:#fff}
.btn-outline{background:transparent;color:var(--red)}
.btn-outline:hover{background:var(--red);color:#fff}

/* ---------- Hero ------------------------------------------------------ */
.hero{background:var(--soft);border-bottom:1px solid var(--line)}
.hero .container{padding-block:88px 92px;text-align:center;max-width:820px}
.hero h1{font-size:clamp(1.9rem,4.4vw,3rem);margin:0 0 24px;color:var(--blue)}
.hero .sub{font-size:1.2rem;color:var(--muted);font-style:italic;margin:0 0 10px}
.hero .attrib{color:var(--red);font-family:var(--serif);font-size:1rem;letter-spacing:.06em;text-transform:uppercase;margin:0 0 32px}

/* ---------- Page hero ------------------------------------------------- */
.page-hero{background:var(--soft);border-bottom:1px solid var(--line)}
.page-hero .container{padding-block:48px;text-align:center}
.page-hero h1{margin:0 0 8px;font-size:clamp(1.7rem,3.4vw,2.4rem)}
.crumbs{font-size:.85rem;color:var(--muted)}
.crumbs a{color:var(--muted)}
.crumbs a:hover{color:var(--red)}

/* ---------- Sections -------------------------------------------------- */
section{padding-block:64px}
.section.soft{background:var(--soft)}
h2{font-size:clamp(1.5rem,2.8vw,2rem);margin:0 0 8px}
.subtitle{color:var(--red);font-weight:600;font-family:var(--serif);margin:0 0 22px}
p{margin:0 0 16px}
.prose p{color:var(--muted)}
.lead{font-size:1.1rem;color:var(--muted)}

/* two-column intro with portrait */
.split{display:grid;grid-template-columns:1.3fr 1fr;gap:48px;align-items:start}
.split.rev{grid-template-columns:1fr 1.3fr}
.split .portrait{border-radius:3px;box-shadow:0 12px 40px rgba(28,58,99,.14);width:100%}
.split figure{margin:0}

/* quote block */
.quote{background:var(--blue);color:#f4f1ea}
.quote .container{max-width:760px;text-align:center;padding-block:64px}
.quote h2{color:#fff}
.quote p{font-family:var(--serif);font-size:1.3rem;font-style:italic;color:#e7e9ef;margin:0 0 14px}
.quote .attrib{color:#c9b3ad;letter-spacing:.06em;text-transform:uppercase;font-size:.9rem;margin-bottom:26px}
.quote .btn-outline{border-color:#fff;color:#fff}
.quote .btn-outline:hover{background:#fff;color:var(--blue)}

/* bio credentials list */
.creds p{color:var(--muted);margin:0 0 14px}
.creds strong{color:var(--ink)}

/* education */
.edu-item{border-left:3px solid var(--red);padding:4px 0 4px 20px;margin-bottom:22px}
.edu-item .school{font-family:var(--serif);color:var(--blue);font-weight:700;font-size:1.08rem}
.edu-item p{margin:4px 0 0;color:var(--muted)}

/* ---------- Gallery --------------------------------------------------- */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.gallery-grid a{display:block;position:relative;overflow:hidden;border-radius:2px;background:#000}
.gallery-grid img{width:100%;height:260px;object-fit:cover;transition:transform .3s ease,opacity .3s}
.gallery-grid a:hover img{transform:scale(1.05);opacity:.9}
.gallery-grid .cap{position:absolute;left:0;right:0;bottom:0;padding:10px 12px;color:#fff;font-size:.82rem;
  background:linear-gradient(transparent,rgba(20,30,45,.8));opacity:0;transition:opacity .2s}
.gallery-grid a:hover .cap{opacity:1}

/* ---------- Contact --------------------------------------------------- */
.contact-card{max-width:520px;margin:0 auto;text-align:center;background:var(--soft);border:1px solid var(--line);border-radius:4px;padding:44px 32px}
.contact-card h2{margin-bottom:24px}
.contact-row{font-size:1.15rem;margin-bottom:16px}
.contact-row .label{font-family:var(--serif);color:var(--blue);font-weight:700;display:block;font-size:.9rem;letter-spacing:.05em;text-transform:uppercase;margin-bottom:2px}

/* ---------- Footer ---------------------------------------------------- */
.site-footer{background:var(--blue);color:#c9d2e0}
.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;padding-block:26px;flex-wrap:wrap;font-size:.92rem}
.site-footer a{color:#e7c9c4}
.site-footer a:hover{color:#fff}

/* ---------- News / Blog cards ---------------------------------------- */
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.news-card{display:flex;flex-direction:column;background:var(--white);border:1px solid var(--line);border-radius:4px;overflow:hidden;transition:.18s;color:var(--ink)}
.news-card:hover{transform:translateY(-3px);box-shadow:0 14px 34px rgba(28,58,99,.12);color:var(--ink)}
.news-card img{width:100%;height:200px;object-fit:cover}
.news-card .news-body{padding:18px 20px}
.news-card .news-date{color:var(--red);font-size:.8rem;font-family:var(--serif);letter-spacing:.04em;text-transform:uppercase}
.news-card h3{font-size:1.05rem;margin:8px 0 0;line-height:1.35;color:var(--blue)}

/* blog article */
.article{max-width:760px;margin:0 auto}
.article .article-date{color:var(--red);font-family:var(--serif);letter-spacing:.05em;text-transform:uppercase;font-size:.85rem;margin-bottom:10px}
.article-hero-img{width:100%;border-radius:4px;margin:0 0 28px;box-shadow:0 12px 40px rgba(28,58,99,.14)}
.article-body{color:var(--ink)}
.article-body p{color:#3a434f;margin:0 0 18px}
.article-body h4{font-family:var(--serif);color:var(--blue);font-size:1.2rem;margin:28px 0 10px}
.article-body blockquote{margin:22px 0;padding:14px 22px;border-left:3px solid var(--red);background:var(--soft);color:#3a434f;font-style:italic;border-radius:3px}
.article-body strong{color:var(--ink)}
.article-source{margin-top:30px;padding-top:18px;border-top:1px solid var(--line);font-size:.92rem;color:var(--muted)}
.yt-link{display:inline-flex;align-items:center;gap:10px;background:var(--red);color:#fff;padding:14px 26px;border-radius:3px;font-family:var(--serif);margin:6px 0 24px}
.yt-link:hover{background:var(--red-2);color:#fff}
.back-link{display:inline-block;margin-top:34px;font-family:var(--serif)}

@media (max-width:860px){.news-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.news-grid{grid-template-columns:1fr}}

@media (prefers-reduced-motion:reduce){*{scroll-behavior:auto;transition:none!important}}

/* ---------- Responsive ------------------------------------------------ */
@media (max-width:860px){
  .split,.split.rev{grid-template-columns:1fr;gap:28px}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:560px){
  .gallery-grid{grid-template-columns:1fr}
  .gallery-grid img{height:300px}
  .header-inner{flex-wrap:wrap}
  .nav-toggle-label{display:inline-flex;flex-direction:column;gap:5px;cursor:pointer;padding:6px}
  .nav-toggle-label span{width:26px;height:2px;background:var(--blue);display:block}
  .main-nav{flex-basis:100%;display:none}
  .nav-toggle:checked ~ .main-nav{display:block}
  .main-nav ul{flex-direction:column;gap:0;align-items:stretch}
  .main-nav li{border-top:1px solid var(--line)}
  .main-nav a{display:block;padding:12px 0}
  .footer-inner{flex-direction:column;align-items:flex-start;gap:8px}
}

/* video-only blog card placeholder */
.news-vid{width:100%;height:200px;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--blue),#2b5088);color:#fff}
.news-vid span{font-family:var(--serif);font-size:1.1rem;letter-spacing:.03em}
