/* portraitsoftheself.com — ru_europe_travel
   Palette: bg #F7F5F0 · ink #2B2625 · accent #B09B81 · sub #6B6260 · panel #3D3735
   Fonts: 'Bodoni Moda', serif · 'Montserrat', sans-serif
*/

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;background:#F7F5F0;color:#2B2625;
  font-family:'Montserrat', sans-serif;
  font-size:16px;line-height:1.7;
}
img{max-width:100%;display:block;height:auto}
a{color:#3D3735;text-underline-offset:3px;text-decoration-thickness:1px}
a:hover{color:#B09B81}
h1,h2,h3,h4{
  font-family:'Bodoni Moda', serif;
  font-weight:400;color:#2B2625;line-height:1.2;margin:0 0 .55em;
}
h1{font-size:clamp(2.2rem,5vw,4rem)}
h2{font-size:clamp(1.6rem,3vw,2.2rem)}
h3{font-size:1.3rem}
p{margin:0 0 1em}

.cont{max-width:1240px;margin:0 auto;padding:0 28px}
.tight{max-width:760px;margin:0 auto;padding:0 28px}

.bar{background:#3D3735;color:#F7F5F0;padding:10px 0;font-size:.78rem;letter-spacing:.08em;font-family:'Bodoni Moda', serif}
.bar .cont{display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px}
.bar a{color:#B09B81;text-decoration:none}
.head{background:#F7F5F0;border-bottom:2px solid #3D3735;padding:18px 0;position:sticky;top:0;z-index:50}
.head .row{display:flex;justify-content:space-between;align-items:center;gap:24px}
.brand{display:flex;align-items:center;gap:14px;text-decoration:none;color:#2B2625}
.brand:hover{color:#B09B81}
.brand-anchor{width:46px;height:46px;background:#3D3735;border-radius:0 0 24px 24px;display:grid;place-items:center}
.brand-anchor svg{width:24px;height:24px}
.brand-name{font-family:'Bodoni Moda', serif;font-size:1.35rem;letter-spacing:-.012em}
.brand-name em{color:#B09B81;font-style:normal}
.menu{display:flex;list-style:none;gap:24px;margin:0;padding:0;font-family:'Bodoni Moda', serif;font-size:.9rem}
.menu a{color:#2B2625;text-decoration:none;padding:6px 0;border-bottom:2px solid transparent}
.menu a:hover,.menu a.on{color:#B09B81;border-bottom-color:#B09B81}
.tog{display:none;background:none;border:0;cursor:pointer;padding:8px}
.tog span{display:block;width:22px;height:2px;background:#2B2625;margin:5px 0}

.hero{padding:80px 0 50px;border-bottom:2px solid #3D3735;position:relative;overflow:hidden}
.hero::after{
  content:"";position:absolute;top:50%;right:-100px;transform:translateY(-50%);
  width:520px;height:520px;border-radius:50%;background:#3D3735;opacity:.04;z-index:0;
}
.hero .cont{position:relative;z-index:1}
.hero .tag{display:inline-block;background:#3D3735;color:#F7F5F0;padding:6px 16px;font-family:'Bodoni Moda', serif;font-size:.78rem;text-transform:uppercase;letter-spacing:.16em;margin-bottom:22px}
.hero h1{max-width:920px}
.hero h1 em{color:#B09B81;font-style:italic}
.hero .deck{font-family:'Montserrat', sans-serif;font-size:1.18rem;color:#6B6260;max-width:720px;margin-top:18px;line-height:1.55}
.hero-fig{margin-top:50px;border:1px solid #3D3735;background:#3D3735}
.hero-fig img{width:100%;aspect-ratio:21/9;object-fit:cover;opacity:.96}
.hero-fig figcaption{font-family:'Bodoni Moda', serif;font-size:.82rem;letter-spacing:.04em;color:#2B2625;background:#F7F5F0;padding:10px 16px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;border-top:1px solid #3D3735}

.fields{padding:80px 0;background:#F7F5F0}
.fields .head-row{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:20px;margin-bottom:50px;border-bottom:1px solid #3D3735;padding-bottom:14px}
.fields .head-row .label{font-family:'Bodoni Moda', serif;font-size:.8rem;color:#B09B81;text-transform:uppercase;letter-spacing:.16em}
.fields .head-row h2{margin:0}
.fields .head-row p{margin:0;max-width:380px;color:#6B6260}

.report{display:grid;grid-template-columns:.85fr 1.4fr;gap:50px;padding:50px 0;border-bottom:1px dashed #3D3735}
.report:first-of-type{padding-top:0}
.report:last-of-type{border-bottom:0}
.report .visual img{width:100%;aspect-ratio:5/4;object-fit:cover;border:1px solid #3D3735}
.report .info-row{display:flex;justify-content:space-between;font-family:'Bodoni Moda', serif;font-size:.78rem;text-transform:uppercase;letter-spacing:.12em;color:#3D3735;margin-bottom:12px}
.report .info-row .pin{color:#B09B81;font-weight:700}
.report h3{font-size:1.7rem;line-height:1.2;margin-bottom:14px}
.report h3 a{color:#2B2625;text-decoration:none}
.report h3 a:hover{color:#B09B81}
.report p{font-size:1rem;color:#6B6260}
.report .read{display:inline-block;margin-top:14px;font-family:'Bodoni Moda', serif;font-size:.82rem;text-transform:uppercase;letter-spacing:.12em;color:#B09B81;text-decoration:none;border-bottom:1.5px solid #B09B81;padding-bottom:1px}

.coord{background:#3D3735;color:#F7F5F0;padding:34px 0;font-family:'Bodoni Moda', serif;font-size:.85rem;letter-spacing:.16em;text-transform:uppercase}
.coord .cont{display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;align-items:center}
.coord strong{color:#B09B81;letter-spacing:.04em}

.author{padding:70px 0;background:#3D3735;color:#F7F5F0}
.author .grid{display:grid;grid-template-columns:auto 1fr;gap:36px;align-items:center}
.author img{width:140px;height:140px;border-radius:50%;object-fit:cover;border:3px solid #B09B81}
.author .role{font-family:'Bodoni Moda', serif;font-size:.78rem;color:#B09B81;text-transform:uppercase;letter-spacing:.16em;margin-bottom:10px}
.author h3{color:#F7F5F0;font-size:1.45rem;margin-bottom:6px}
.author p{margin:0;color:#ccd5d1;font-size:.95rem}
.author a{color:#B09B81}

.ph{padding:80px 0 30px;border-bottom:2px solid #3D3735}
.ph .tag{display:inline-block;background:#B09B81;color:#F7F5F0;padding:6px 14px;font-family:'Bodoni Moda', serif;font-size:.78rem;text-transform:uppercase;letter-spacing:.14em;font-weight:600}
.ph h1{margin-top:14px;max-width:840px}
.ph p{font-size:1.15rem;color:#6B6260;font-style:italic;max-width:680px;margin-top:10px}

.prose{padding:50px 0 80px}
.prose p{font-size:1.02rem;margin-bottom:1.2em}
.prose h2{font-size:1.75rem;margin-top:46px;border-bottom:1px solid #3D3735;padding-bottom:8px;display:flex;align-items:center;gap:10px}
.prose h2::before{content:"▮";color:#B09B81;font-size:.85em}
.prose h3{font-size:1.18rem;margin-top:28px;color:#B09B81;font-family:'Bodoni Moda', serif;text-transform:uppercase;letter-spacing:.04em}
.prose ul,.prose ol{padding-left:1.5em;margin-bottom:1.2em}
.prose li{margin-bottom:.5em}
.prose blockquote{border-left:3px solid #B09B81;padding:6px 0 6px 24px;margin:28px 0;font-family:'Bodoni Moda', serif;font-style:italic;font-size:1.2rem;line-height:1.5;color:#2B2625}

.art-h{padding:70px 0 30px;border-bottom:1px solid #3D3735}
.art-h .crumbs{font-family:'Bodoni Moda', serif;font-size:.8rem;color:#B09B81;letter-spacing:.1;text-transform:uppercase;margin-bottom:20px}
.art-h h1{max-width:920px;margin-bottom:14px}
.art-h .deck{font-family:'Montserrat', sans-serif;font-size:1.18rem;color:#6B6260;max-width:780px;line-height:1.55}
.art-h .by{margin-top:28px;display:flex;align-items:center;gap:18px;font-size:.92rem;color:#6B6260;flex-wrap:wrap}
.art-h .by img{width:54px;height:54px;border-radius:50%;object-fit:cover;border:2px solid #B09B81}
.art-h .by strong{color:#2B2625;display:block;font-family:'Bodoni Moda', serif;font-size:.95rem}
.art-fig{margin:36px auto;max-width:1240px;padding:0 28px}
.art-fig img{width:100%;aspect-ratio:16/9;object-fit:cover;border:1px solid #3D3735}
.art-fig figcaption{font-family:'Bodoni Moda', serif;font-size:.82rem;color:#6B6260;margin-top:10px;letter-spacing:.04em}
.art-body{padding:20px 0 60px}
.art-body p{font-size:1.02rem;line-height:1.75;margin-bottom:1.3em}
.art-body p:first-of-type::first-letter{font-family:'Bodoni Moda', serif;font-size:4.2rem;float:left;line-height:.85;padding:8px 14px 0 0;color:#B09B81}
.art-body h2{font-size:1.75rem;margin:1.7em 0 .5em;display:flex;align-items:center;gap:10px}
.art-body h2::before{content:"▮";color:#B09B81}
.art-body h3{font-size:1.18rem;margin:1.4em 0 .4em;color:#B09B81;font-family:'Bodoni Moda', serif;text-transform:uppercase;letter-spacing:.04em}
.art-body blockquote{border-left:3px solid #B09B81;padding:8px 0 8px 26px;margin:32px 0;font-style:italic;font-family:'Bodoni Moda', serif;font-size:1.25rem;line-height:1.45}
.art-body ul,.art-body ol{padding-left:1.5em;margin-bottom:1.2em}
.art-body li{margin-bottom:.45em}
.art-body hr{border:0;border-top:1px solid #3D3735;margin:50px 0}

.art-end{padding:30px 0 60px;border-top:2px solid #3D3735}
.art-end .tag{font-family:'Bodoni Moda', serif;font-size:.78rem;color:#B09B81;text-transform:uppercase;letter-spacing:.14em}
.art-end h3{font-family:'Bodoni Moda', serif;font-style:italic;font-size:1.35rem;font-weight:400;margin-top:8px}

.fld{display:flex;flex-direction:column;gap:6px;margin-bottom:18px}
.fld label{font-family:'Bodoni Moda', serif;font-size:.82rem;color:#2B2625;text-transform:uppercase;letter-spacing:.06em}
.fld input,.fld textarea,.fld select{background:#fff;border:1.5px solid #3D3735;border-radius:0;padding:11px 14px;font:inherit;color:#2B2625}
.fld input:focus,.fld textarea:focus{outline:none;border-color:#B09B81;box-shadow:0 0 0 3px #B09B8133}
.fld textarea{min-height:140px;resize:vertical}
.btn{display:inline-block;background:#B09B81;color:#F7F5F0;padding:13px 26px;font-family:'Bodoni Moda', serif;font-size:.88rem;text-transform:uppercase;letter-spacing:.12em;border:0;cursor:pointer}
.btn:hover{background:#3D3735;color:#F7F5F0}

.foot{background:#3D3735;color:#a2b2ab;padding:60px 0 28px}
.foot a{color:#ccd5d1}
.foot a:hover{color:#B09B81}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:36px;margin-bottom:40px}
.foot h4{color:#F7F5F0;font-family:'Bodoni Moda', serif;font-size:.88rem;text-transform:uppercase;letter-spacing:.14em;margin-bottom:14px}
.foot ul{list-style:none;padding:0;margin:0;line-height:2;font-size:.92rem}
.foot-tag{font-family:'Bodoni Moda', serif;font-style:italic;font-size:1.25rem;color:#F7F5F0;line-height:1.35;margin:0 0 10px}
.foot-bar{border-top:1px solid #32433d;padding-top:20px;font-size:.82rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;font-family:'Bodoni Moda', serif;letter-spacing:.04em}

.reveal{opacity:0;transform:translateY(20px);transition:opacity .85s,transform .85s}
.reveal.in{opacity:1;transform:none}

@media (max-width:880px){
  .menu{display:none;position:absolute;top:100%;left:0;right:0;background:#F7F5F0;flex-direction:column;padding:20px 28px;gap:14px;border-bottom:2px solid #3D3735}
  .menu.open{display:flex}
  .tog{display:block}
  .report{grid-template-columns:1fr;gap:24px}
  .author .grid{grid-template-columns:1fr;text-align:left}
  .author img{width:120px;height:120px}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:520px){
  .foot-grid{grid-template-columns:1fr}
}
