/* ═══ olegmiftakhov.ru — hi-fi draft · direction A (Classic Journal) ═══ */
:root{
  --accent:#C7452A;
  --paper:#F2EDE4;
  --paper-2:#E9E2D4;
  --paper-3:#DDD5C4;
  --ink:#141311;
  --ink-2:#2b2925;
  --mute:#6f6a60;
  --line:rgba(20,19,17,.18);
  --line-2:rgba(20,19,17,.4);
  --mono:'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, monospace;
  --serif:'IBM Plex Serif', 'Source Serif Pro', Georgia, serif;
  --display:'Fraunces', 'IBM Plex Serif', Georgia, serif;
  --maxw:1180px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--paper);color:var(--ink);
  font-family:var(--serif); font-size:17px; line-height:1.55;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden}
a{color:inherit; text-decoration:none}
a:hover{color:var(--accent)}
img{max-width:100%; display:block}

/* nav */
.nav{
  position:sticky; top:0; z-index:40; background:var(--paper);
  border-bottom:1px solid var(--line);
}
.nav-in{
  max-width:var(--maxw); margin:0 auto; padding:14px 28px;
  display:flex; align-items:center; gap:28px;
  font-family:var(--mono); font-size:13px;
}
.nav-in .me{display:flex; align-items:center; gap:10px; font-weight:600; letter-spacing:-.01em; flex-shrink:0; white-space:nowrap; min-width:0}
.nav-in .me > span:not(.av){white-space:nowrap; overflow:hidden; text-overflow:ellipsis}
.nav-in .me .av{width:28px; height:28px; border-radius:50%; background-size:cover; background-position:center; border:1px solid var(--line-2); flex-shrink:0}
.nav-in .me .dot{color:var(--accent)}
.nav-in nav{display:flex; gap:20px}
.nav-in nav a{color:var(--ink-2)}
.nav-in nav a:hover{color:var(--accent)}
.nav-in nav{flex-shrink:0}
.nav-in .right{margin-left:auto; display:flex; gap:14px; align-items:center; flex-shrink:0}
.nav-in .right .live{color:var(--accent); font-size:12px}
.nav-in .right .live::before{content:"●"; margin-right:6px; animation:blink 1.6s steps(1) infinite}
@keyframes blink{50%{opacity:0}}

/* page */
.page{max-width:var(--maxw); margin:0 auto; padding:0 28px}

/* hero */
.hero{padding:72px 0 48px; border-bottom:1px solid var(--line); max-width:920px}
.hero.with-photo .txt{display:flex; flex-direction:column; justify-content:space-between; min-height:100%}
.hero.with-photo{max-width:none; display:grid; grid-template-columns:minmax(0,1fr) 320px; gap:64px; align-items:stretch}
.hero.with-photo > *:first-child{align-self:start}
.hero .kicker{font-family:var(--mono); font-size:12px; color:var(--accent);
  letter-spacing:.18em; text-transform:uppercase; margin-bottom:18px;
  display:flex; gap:14px; flex-wrap:wrap}
.hero .kicker span:not(:last-child)::after{content:"·"; margin-left:14px; opacity:.5}
.hero h1{margin:0 0 22px; font-family:var(--display);
  font-weight:400; font-size:clamp(40px, 5.2vw, 62px);
  line-height:1.02; letter-spacing:-.025em; font-optical-sizing:auto;
  font-variation-settings:"SOFT" 50, "WONK" 0;}
.hero h1 em{font-style:italic; color:var(--accent); font-weight:500}
.hero .lede{margin:0; font-size:20px; line-height:1.5; color:var(--ink-2); max-width:720px}
.hero .portrait{aspect-ratio:3/4; width:100%; min-height:0; background-size:contain; background-repeat:no-repeat; background-position:center;
  background-color:transparent; border:0; filter:grayscale(.05) contrast(1.02)}

/* now */
.now{
  position:relative;
  display:grid; grid-template-columns:220px minmax(0,1fr) 260px; gap:44px;
  padding:40px 0; border-bottom:1px solid var(--line);
  margin:0;
}
.now::before{
  content:""; position:absolute; top:0; bottom:0; left:50%; transform:translateX(-50%);
  width:100vw; background:var(--paper-2);
}
.now > *{position:relative}
.now .lbl{font-family:var(--mono); font-size:11px; color:var(--mute);
  text-transform:uppercase; letter-spacing:.18em; padding-top:8px}
.now .lbl b{display:block; font-family:var(--display); font-size:26px;
  font-weight:600; color:var(--ink); text-transform:none; letter-spacing:-.02em;
  margin-bottom:6px; line-height:1}
.now .lbl b::after{content:" ◉"; color:var(--accent); font-size:.7em; vertical-align:middle}
.now .lbl .upd{margin-top:12px; display:block; font-size:10px}
.now ul{list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:16px}
.now li{display:grid; grid-template-columns:28px 1fr 110px; gap:14px; align-items:center;
  font-size:18px; line-height:1.45}
.now li .tag{justify-self:end; align-self:center}
.now li .i{font-family:var(--mono); color:var(--accent); font-weight:500; font-size:13px; padding-top:3px}
.now li b{font-weight:600}
.now .tag{display:inline-flex; align-items:center; justify-content:center; font-family:var(--mono); font-size:10px;
  text-transform:uppercase; letter-spacing:.12em; text-indent:.12em; padding:2px 12px 0; min-width:92px; height:24px; line-height:1;
  border:1px solid var(--line-2); border-radius:2px; white-space:nowrap;
  color:var(--mute); background:var(--paper); text-align:center}
.now .tag.on{background:var(--accent); color:#fff; border-color:var(--accent)}
.now aside{border-left:1px dashed var(--line-2); padding-left:24px; font-family:var(--mono); font-size:13px; line-height:1.7}
.now aside h4{margin:0 0 8px; font-size:10px; text-transform:uppercase; letter-spacing:.18em; color:var(--mute); font-weight:600}
.now aside .place{border:1px solid var(--line-2); padding:14px; margin:14px 0; background:var(--paper)}
.now aside .place b{color:var(--accent); font-weight:600}
.now aside a{display:block; padding:2px 0; color:var(--ink-2)}
.now aside a:hover{color:var(--accent)}

/* feed */
.feed{display:grid; grid-template-columns:160px minmax(0,1fr) 260px; gap:44px; padding:56px 0}
.feed .lbl{font-family:var(--mono); font-size:11px; color:var(--mute);
  text-transform:uppercase; letter-spacing:.18em; position:sticky; top:78px; align-self:start}
.feed .lbl b{display:block; font-family:var(--display); font-size:26px;
  color:var(--ink); text-transform:none; letter-spacing:-.02em; margin-bottom:4px; font-weight:600}
.feed .posts{display:flex; flex-direction:column; gap:38px}
.feed .post{display:grid; grid-template-columns:100px 1fr; gap:26px; padding-bottom:36px; border-bottom:1px dashed var(--line-2)}
.feed .post:last-child{border-bottom:0}
.feed .post .dt{font-family:var(--mono); font-size:11px; color:var(--mute); line-height:1.4}
.feed .post .dt b{display:block; color:var(--accent); font-size:15px; margin-bottom:2px; font-weight:500}
.feed .post .dt .n{display:block; margin-top:10px; color:var(--mute); letter-spacing:.15em; text-transform:uppercase; font-size:10px}
.feed .post h3{margin:-4px 0 10px; font-family:var(--display); font-size:30px;
  font-weight:500; line-height:1.1; letter-spacing:-.02em;
  font-variation-settings:"SOFT" 50}
.feed .post h3 em{font-style:italic; color:var(--accent); font-weight:500}
.feed .post p{margin:0 0 12px; font-size:17px; line-height:1.55; color:var(--ink-2); max-width:640px}
.feed .post .meta{font-family:var(--mono); font-size:12px; color:var(--mute); display:flex; gap:16px; flex-wrap:wrap}
.feed .post .meta .read{color:var(--accent); font-weight:500}
.feed .post.short h3{font-size:20px; font-family:var(--serif); font-style:italic; font-weight:500}
.feed aside{border-left:1px dashed var(--line-2); padding-left:24px; position:sticky; top:78px; align-self:start}
.feed aside h4{margin:0 0 10px; font-family:var(--mono); font-size:10px;
  text-transform:uppercase; letter-spacing:.18em; color:var(--mute); font-weight:600}
.feed aside ul{list-style:none; padding:0; margin:0 0 22px; font-size:15px; line-height:1.75}
.feed aside li{display:grid; grid-template-columns:18px 1fr auto; gap:8px; align-items:baseline; padding:2px 0}
.feed aside li::before{content:"→"; color:var(--accent); font-family:var(--mono); opacity:.6}
.feed aside li a, .feed aside li > span:first-of-type{min-width:0}
.feed aside li span{color:var(--mute); font-family:var(--mono); font-size:11px; text-align:right}
.feed aside .box{border:1px solid var(--line-2); padding:16px; font-family:var(--mono); font-size:12px; line-height:1.55; background:var(--paper-2)}
.feed aside .box b{color:var(--accent); display:block; margin-bottom:4px; font-size:13px}

/* footer */
.footer{border-top:1px solid var(--line); padding:40px 0 56px; margin-top:40px;
  display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:32px;
  font-family:var(--mono); font-size:13px; color:var(--ink-2)}
.footer .brand{grid-column:auto; padding-bottom:0; border-bottom:0; margin-bottom:0}
.footer h4{margin:0 0 10px; font-size:10px; text-transform:uppercase; letter-spacing:.18em; color:var(--mute); font-weight:600}
.footer .brand b{font-family:var(--display); font-size:20px; color:var(--ink); display:block; margin-bottom:6px; letter-spacing:-.01em; font-weight:600}
.footer .brand{font-size:13px; line-height:1.6; max-width:320px; color:var(--mute)}
.footer a{display:block; padding:2px 0; color:var(--ink-2)}
.footer a:hover{color:var(--accent)}

/* ═══ article page (post / project) ═══ */
.article{max-width:720px; margin:0 auto; padding:60px 28px 40px}
.article .crumb{font-family:var(--mono); font-size:12px; color:var(--mute); margin-bottom:20px; letter-spacing:.08em}
.article .crumb a{color:var(--mute)}
.article .crumb a:hover{color:var(--accent)}
.article .kicker{font-family:var(--mono); font-size:12px; color:var(--accent); letter-spacing:.18em; text-transform:uppercase; margin-bottom:14px}
.article h1{margin:0 0 16px; font-family:var(--display); font-size:clamp(34px, 4vw, 52px);
  line-height:1.05; letter-spacing:-.025em; font-weight:500; font-optical-sizing:auto}
.article h1 em{font-style:italic; color:var(--accent)}
.article .dek{margin:0 0 28px; font-size:20px; line-height:1.5; color:var(--ink-2); font-style:italic; max-width:640px}
.article .meta{display:flex; gap:22px; padding:14px 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line);
  font-family:var(--mono); font-size:12px; color:var(--mute); align-items:center; flex-wrap:wrap}
.article .meta .author{display:flex; align-items:center; gap:8px}
.article .meta .author img{width:22px; height:22px; border-radius:50%; border:1px solid var(--line-2)}
.article .meta .author b{color:var(--ink); font-family:var(--serif); font-size:13px; font-weight:600}
.article .meta .dot{color:var(--accent)}

.article .body{padding:36px 0; font-size:19px; line-height:1.7}
.article .body > p:first-of-type::first-letter{
  font-family:var(--display); font-weight:600; font-size:72px; line-height:.85;
  float:left; padding:10px 12px 0 0; color:var(--accent)}
.article .body h2{margin:40px 0 14px; font-family:var(--display); font-size:30px;
  font-weight:500; letter-spacing:-.015em; line-height:1.15}
.article .body h2::before{content:"§"; color:var(--accent); margin-right:10px; font-family:var(--mono); font-size:22px; vertical-align:3px}
.article .body p{margin:0 0 18px; text-wrap:pretty}
.article .body ul, .article .body ol{margin:0 0 22px; padding-left:24px}
.article .body li{margin-bottom:8px; line-height:1.6}
.article .body li::marker{color:var(--accent)}
.article .body strong{font-weight:600}
.article .body blockquote{margin:28px 0; padding:0 0 0 24px; border-left:3px solid var(--accent);
  font-style:italic; color:var(--ink-2); font-size:22px; line-height:1.45}
.article .body img{margin:28px 0; border:1px solid var(--line-2)}

.article .tags{display:flex; gap:8px; flex-wrap:wrap; margin:8px 0 32px}
.article .tags .t{font-family:var(--mono); font-size:11px; text-transform:uppercase; letter-spacing:.12em;
  padding:4px 10px; border:1px solid var(--line-2); color:var(--mute)}
.article .tags .t:hover{color:var(--accent); border-color:var(--accent)}

.article .post-foot{padding:28px 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line);
  display:flex; justify-content:space-between; align-items:center; gap:20px; flex-wrap:wrap;
  font-family:var(--mono); font-size:13px}
.article .post-foot .links{display:flex; gap:20px}
.article .post-foot .cta{color:var(--accent); font-weight:500}

.article .more{padding:40px 0}
.article .more h4{margin:0 0 20px; font-family:var(--mono); font-size:11px; text-transform:uppercase; letter-spacing:.18em; color:var(--mute); font-weight:600}
.article .more .grid{display:grid; grid-template-columns:1fr 1fr; gap:24px}
.article .more .card{padding:18px 0; border-top:1px solid var(--line)}
.article .more .card .dt{font-family:var(--mono); font-size:11px; color:var(--mute); margin-bottom:6px}
.article .more .card h5{margin:0; font-family:var(--display); font-size:20px; font-weight:500; line-height:1.2; letter-spacing:-.01em}

/* project page specifics */
.project-head{border-bottom:1px solid var(--line); padding-bottom:28px; margin-bottom:0}
.project-stats{display:grid; grid-template-columns:repeat(4, 1fr); gap:0;
  border:1px solid var(--line-2); margin:28px 0; background:var(--paper-2)}
.project-stats .s{padding:16px 18px; border-right:1px solid var(--line-2); font-family:var(--mono); font-size:12px}
.project-stats .s:last-child{border-right:0}
.project-stats .k{font-size:10px; color:var(--mute); text-transform:uppercase; letter-spacing:.15em; margin-bottom:6px}
.project-stats .v{font-family:var(--display); font-size:20px; color:var(--ink); font-weight:500; letter-spacing:-.01em; line-height:1.1}
.project-stats .v em{color:var(--accent); font-style:normal}

/* ═══ responsive ═══ */
.nav-burger{display:none; margin-left:auto; width:40px; height:40px; border:1px solid var(--line-2);
  background:transparent; padding:0; cursor:pointer; position:relative; align-items:center; justify-content:center}
.nav-burger span{display:block; width:18px; height:1.5px; background:var(--ink); position:relative}
.nav-burger span::before, .nav-burger span::after{content:""; position:absolute; left:0; width:18px; height:1.5px; background:var(--ink); transition:transform .25s}
.nav-burger span::before{top:-6px}
.nav-burger span::after{top:6px}
.nav-burger.on span{background:transparent}
.nav-burger.on span::before{top:0; transform:rotate(45deg)}
.nav-burger.on span::after{top:0; transform:rotate(-45deg)}

@media (max-width: 940px){
  .hero.with-photo{grid-template-columns:1fr; gap:32px}
  .hero .portrait{width:100% !important; max-width:340px; height:380px !important; margin:0 auto}
  .now{grid-template-columns:1fr; gap:24px; margin:0; padding:32px 0}
  .now aside{border-left:0; padding-left:0; border-top:1px dashed var(--line-2); padding-top:20px}
  .feed{grid-template-columns:1fr; gap:28px}
  .feed .lbl, .feed aside{position:static}
  .feed aside{border-left:0; padding-left:0; border-top:1px dashed var(--line-2); padding-top:24px}
  .footer{grid-template-columns:1fr 1fr; gap:24px 48px}
  .footer .brand{grid-column:1 / -1; padding-bottom:16px; border-bottom:1px dashed var(--line-2); margin-bottom:8px}
  .project-stats{grid-template-columns:1fr 1fr}
  .project-stats .s:nth-child(2n){border-right:0}
  .article .more .grid{grid-template-columns:1fr}
}

/* nav → burger уже с планшетной ширины, пока всё горизонтальное меню ещё помещается, оно остаётся */
@media (max-width: 1024px){
  .nav-in{padding:12px 20px; gap:12px; flex-wrap:nowrap; position:relative}
  .nav-in nav{display:none; position:absolute; top:100%; left:0; right:0;
    background:var(--paper); border-bottom:1px solid var(--line-2);
    flex-direction:column; padding:8px 20px 16px; gap:0; z-index:50}
  .nav-in nav.on{display:flex}
  .nav-in nav a{padding:14px 0; border-bottom:1px dashed var(--line);
    font-size:15px; font-family:var(--display); letter-spacing:-.01em}
  .nav-in nav a:last-child{border-bottom:0}
  .nav-burger{display:inline-flex}
  .nav-in .right{display:none}
}

@media (max-width: 720px){
  html,body{font-size:16px}
  .page{padding:0 18px}
  .nav-in{padding:12px 18px}
  .nav-in .me span:not(.av):not(.dot){display:none}

  .hero{padding:40px 0 32px}
  .hero .kicker{font-size:11px; gap:8px; margin-bottom:14px; flex-wrap:wrap}
  .hero h1{font-size:34px; letter-spacing:-.02em; margin-bottom:16px}
  .hero .lede{font-size:17px}
  .hero.with-photo{gap:24px}
  .hero .portrait{max-width:100%; height:300px !important}

  .now{padding:28px 0; gap:20px}
  .now .lbl b{font-size:22px}
  .now li{grid-template-columns:22px 1fr; font-size:16px; line-height:1.4}
  .now li .tag{grid-column:2; justify-self:start; margin-top:4px}
  .now aside{font-size:12px}

  .feed{padding:36px 0; gap:20px}
  .feed .lbl b{font-size:22px}
  .feed .post{grid-template-columns:60px 1fr; gap:14px; padding-bottom:26px}
  .feed .post .dt{font-size:10px}
  .feed .post .dt b{font-size:13px}
  .feed .post .dt .n{display:none}
  .feed .post h3{font-size:22px; margin:-2px 0 8px}
  .feed .post.short h3{font-size:17px}
  .feed .post p{font-size:15px}
  .feed .post .meta{gap:10px; font-size:11px; flex-wrap:wrap}
  .feed aside li{grid-template-columns:16px 1fr auto; gap:6px}

  .footer{grid-template-columns:1fr 1fr; gap:20px 24px; padding:32px 0 44px}
  .footer .brand{max-width:none}

  .article{padding:36px 18px 28px}
  .article h1{font-size:30px}
  .article .dek{font-size:17px}
  .article .body{font-size:17px; padding:24px 0; line-height:1.6}
  .article .body > p:first-of-type::first-letter{font-size:52px}
  .article .body h2{font-size:24px; margin:32px 0 10px}
  .article .body blockquote{font-size:18px; padding-left:18px; margin:22px 0}
  .article .meta{gap:12px; font-size:11px; flex-wrap:wrap}
  .article .post-foot{flex-direction:column; align-items:flex-start; gap:12px}

  .project-stats{grid-template-columns:1fr 1fr}

  #switch{right:10px; bottom:10px; font-size:11px; padding:8px 10px}

  .archive-grid{grid-template-columns:1fr !important; gap:24px !important}
  .archive-grid aside{border-left:0 !important; padding-left:0 !important;
    border-top:1px dashed var(--line-2); padding-top:20px}
  .archive-head h1{font-size:30px !important}
  .entry{grid-template-columns:52px 1fr !important; gap:12px !important}
  .entry .k{display:none !important}
  .filter-bar{flex-wrap:wrap !important; font-size:11px !important; gap:6px !important}
  .filter-bar .c{display:none !important}
}

@media (max-width: 420px){
  .hero h1{font-size:28px}
  .feed .post h3{font-size:20px}
  .article h1{font-size:26px}
}
