/* Pages CSS — shared by about / services / gallery / cases / contact / blog */
.site-head{position:sticky;top:0;z-index:90;background:rgba(245,239,227,.92);backdrop-filter:blur(10px);border-bottom:1px solid rgba(11,30,45,.08)}
.site-head__inner{max-width:1400px;margin:0 auto;padding:16px 40px;display:flex;align-items:center;gap:32px}
.site-head__brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:#0b1e2d}
.site-head__brand img{width:36px;height:36px;object-fit:contain}
.site-head__brand span{display:flex;flex-direction:column;line-height:1.1}
.site-head__brand strong{font-family:'Fraunces',serif;font-weight:400;font-size:16px}
.site-head__brand em{font-style:normal;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:#0b1e2d99}
.site-head__nav{display:flex;gap:24px;margin-left:auto;font-size:13px}
.site-head__nav a{color:#0b1e2d;text-decoration:none;padding:8px 0;border-bottom:1px solid transparent;transition:.2s}
.site-head__nav a:hover,.site-head__nav a.on{border-color:#b8894a}
.site-head__right{display:flex;gap:16px;align-items:center}
.lang-pick{position:relative}
.lang-pick button{background:none;border:1px solid rgba(11,30,45,.2);padding:6px 12px;border-radius:4px;font-family:'JetBrains Mono',monospace;font-size:11px;cursor:pointer;color:#0b1e2d}
.lang-pick__menu{position:absolute;top:calc(100% + 4px);right:0;background:#f5efe3;border:1px solid rgba(11,30,45,.15);border-radius:4px;padding:4px;display:none;flex-direction:column;min-width:60px;box-shadow:0 8px 24px rgba(0,0,0,.15)}
.lang-pick:hover .lang-pick__menu,.lang-pick:focus-within .lang-pick__menu{display:flex}
.lang-pick__menu a{padding:6px 12px;text-decoration:none;color:#0b1e2d;font-family:'JetBrains Mono',monospace;font-size:11px;border-radius:3px}
.lang-pick__menu a:hover{background:rgba(184,137,74,.15)}
.btn--sm{padding:8px 14px;font-size:12px}

.pgsec{padding:80px 0}
.pgsec--hero{padding:120px 0 60px;background:#f5efe3}
.pgsec--navy{background:#0b1e2d;color:#f5efe3}
.pgwrap{max-width:1200px;margin:0 auto;padding:0 40px}
.pgwrap--narrow{max-width:760px}
.pgwrap--split{display:grid;grid-template-columns:320px 1fr;gap:64px}
.eyebrow{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:#b8894a;margin-bottom:16px}
.pg-h1{font-family:'Fraunces',serif;font-weight:300;font-size:clamp(40px,6vw,72px);line-height:1.05;margin:0 0 24px;letter-spacing:-.02em}
.pg-h2{font-family:'Fraunces',serif;font-weight:400;font-size:clamp(28px,3.5vw,40px);line-height:1.15;margin:0 0 16px}
.pg-lede{font-size:18px;line-height:1.6;max-width:640px;color:#0b1e2d99}
.pgsec--navy .pg-lede{color:rgba(245,239,227,.7)}

.timeline{border-left:1px solid rgba(11,30,45,.15);padding-left:40px}
.timeline__row{display:grid;grid-template-columns:80px 1fr;gap:40px;padding:24px 0;border-bottom:1px solid rgba(11,30,45,.08)}
.timeline__year{font-family:'Fraunces',serif;font-size:32px;color:#b8894a}
.timeline__text{font-size:16px;line-height:1.6;padding-top:8px}

.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:40px}
.vcard{padding:28px;background:rgba(245,239,227,.05);border:1px solid rgba(245,239,227,.1);border-radius:4px}
.vcard h3{font-family:'Fraunces',serif;font-weight:400;font-size:20px;margin:0 0 12px;color:#b8894a}
.vcard p{font-size:14px;line-height:1.55;margin:0;color:rgba(245,239,227,.75)}

.svc-row{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;padding:64px 0;border-bottom:1px solid rgba(11,30,45,.08)}
.svc-row img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:2px}
.svc-row--img-left img{order:-1}
.svc-row__tag{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.1em;color:#b8894a;margin-bottom:12px}

.gal-masonry{column-count:3;column-gap:16px}
.gal-masonry figure{break-inside:avoid;margin:0 0 16px}
.gal-masonry img{width:100%;display:block;border-radius:2px}

.case{display:grid;grid-template-columns:1fr 1.2fr;gap:48px;padding:48px 0;border-bottom:1px solid rgba(11,30,45,.08);align-items:center}
.case img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:2px}
.case__sub{font-family:'JetBrains Mono',monospace;font-size:12px;color:#b8894a;margin-bottom:16px}
.case__text p{font-size:16px;line-height:1.65;max-width:520px}

.contact-aside h3{font-family:'Fraunces',serif;font-weight:400;font-size:22px;margin:0 0 16px}
.contact-aside a{color:#0b1e2d;text-decoration:none;border-bottom:1px solid rgba(11,30,45,.2);display:inline-block;margin-bottom:4px}

.qform{display:flex;flex-direction:column;gap:18px}
.qform__row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.qform label{display:flex;flex-direction:column;gap:6px}
.qform label span{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:#0b1e2d99}
.qform input,.qform select,.qform textarea{padding:12px 14px;border:1px solid rgba(11,30,45,.2);background:#fff;font:inherit;border-radius:2px;color:#0b1e2d}
.qform input:focus,.qform select:focus,.qform textarea:focus{outline:none;border-color:#b8894a}
.qform__msg{padding:14px 18px;border-radius:4px;font-size:14px;margin-top:8px}
.qform__msg.ok{background:#e8f4ef;color:#2c6b4f}
.qform__msg.err{background:#fbeceb;color:#c0392b}

.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:32px}
.bpcard{text-decoration:none;color:inherit;display:block;transition:.2s}
.bpcard img{width:100%;aspect-ratio:3/2;object-fit:cover;border-radius:2px;display:block}
.bpcard__body{padding:20px 0}
.bpcard__meta{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.06em;color:#b8894a;margin-bottom:12px}
.bpcard h3{font-family:'Fraunces',serif;font-weight:400;font-size:22px;line-height:1.2;margin:0 0 10px}
.bpcard p{font-size:14px;line-height:1.55;color:#0b1e2dcc;margin:0}
.bpcard:hover h3{color:#b8894a}

.bpost__head{background:#f5efe3;padding:100px 0 60px}
.bpost__back{font-family:'JetBrains Mono',monospace;font-size:11px;color:#b8894a;text-decoration:none;margin-bottom:24px;display:inline-block}
.bpost__meta{font-family:'JetBrains Mono',monospace;font-size:12px;color:#0b1e2d99;margin-bottom:16px}
.bpost__title{font-family:'Fraunces',serif;font-weight:300;font-size:clamp(36px,5vw,56px);line-height:1.1;margin:0 0 20px;max-width:800px}
.bpost__excerpt{font-size:20px;line-height:1.5;max-width:700px;color:#0b1e2dcc;font-family:'Fraunces',serif;font-style:italic;font-weight:300}
.bpost__hero{max-width:1200px;margin:0 auto;padding:0 40px}
.bpost__hero img{width:100%;aspect-ratio:16/7;object-fit:cover;border-radius:2px}
.bpost__body{padding:60px 0 120px}
.bpost__body h2{font-family:'Fraunces',serif;font-weight:400;font-size:28px;margin:48px 0 16px;color:#0b1e2d}
.bpost__body p{font-size:17px;line-height:1.75;margin:0 0 20px;color:#0b1e2dcc}

.site-foot{background:#081824;color:#f5efe3;padding:64px 0 32px}
.site-foot__inner{max-width:1200px;margin:0 auto;padding:0 40px;display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:48px}
.site-foot h4{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:#b8894a;margin:0 0 16px}
.site-foot p{margin:0 0 8px;font-size:14px}
.site-foot a{color:rgba(245,239,227,.7);text-decoration:none}
.site-foot a:hover{color:#b8894a}
.site-foot__legal{max-width:1200px;margin:48px auto 0;padding:24px 40px 0;border-top:1px solid rgba(245,239,227,.1);font-family:'JetBrains Mono',monospace;font-size:11px;color:rgba(245,239,227,.4)}

.wfab{position:fixed;bottom:24px;right:24px;width:56px;height:56px;border-radius:50%;background:#25d366;color:#fff;display:flex;align-items:center;justify-content:center;text-decoration:none;box-shadow:0 8px 24px rgba(0,0,0,.25);z-index:80}

@media (max-width:900px){
  .site-head__nav{display:none}
  .pgwrap--split{grid-template-columns:1fr}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .svc-row,.case{grid-template-columns:1fr;gap:24px}
  .svc-row--img-left img{order:0}
  .gal-masonry{column-count:2}
  .site-foot__inner{grid-template-columns:1fr 1fr}
  .qform__row{grid-template-columns:1fr}
}
@media (max-width:560px){
  .gal-masonry{column-count:1}
  .grid-4,.site-foot__inner{grid-template-columns:1fr}
  .pgsec{padding:48px 0}
}
