/* Minimal, monochrome, editorial */

:root{
  --max:1200px;
  --pad:5%;
  --section:3rem;

  --bg:#ffffff;
  --fg:#0a0a0a;
  --muted:#5f5f5f;
  --border:#ededed;

  --r:6px;
}

/* Base */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:ui-serif,Georgia,"Times New Roman",Times,serif;
  color:var(--fg);
  background:var(--bg);
  line-height:1.65;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;height:auto;display:block}

/* Links */
a{color:inherit;text-decoration:none}
a{
  border-bottom:1px solid transparent;
}
a:hover,
a:focus-visible{
  border-bottom-color:rgba(10,10,10,0.22);
}
.logo,
.main-nav a,
.footer-nav a{
  border-bottom-color:transparent;
}
:focus-visible{outline:2px solid rgba(10,10,10,0.22);outline-offset:3px}

/* Layout primitives */
.wrap{max-width:var(--max);margin:0 auto;padding:0 var(--pad)}
.section{padding:var(--section) 0}
.section h1{
  margin:0 0 10px;
  font-weight:400;
  font-size:2.35rem;
  line-height:1.1;
}
.section p{color:var(--fg)}

/* Header */
.site-header{border-bottom:1px solid var(--border)}
.nav{
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  gap:24px;
  padding:64px 0 44px
}
.logo{
  font-weight:400;
  letter-spacing:.22rem;
  text-transform:uppercase;
  font-size:1.05rem;
  line-height:1;
  white-space:nowrap
}
.main-nav{
  display:flex;
  gap:22px;
  flex-wrap:wrap;
  justify-content:flex-end;
  align-items:center
}
.main-nav a{
  font-size:.78rem;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:1.3px;
  padding:6px 0;
}
.main-nav a:hover,.main-nav a:focus-visible{color:var(--fg)}
.main-nav a.is-active{color:var(--fg)}

/* Prose */
.prose{max-width:70ch}
.prose p{color:var(--fg)}

/* Grid (listing) */
.model-grid{
  display:grid;
  gap:30px;
  grid-template-columns:1fr;
  justify-content:center;
  align-items:start;
  margin-top:var(--section)
}
@media (min-width:600px){.model-grid{grid-template-columns:repeat(2,260px)}}
@media (min-width:900px){.model-grid{grid-template-columns:repeat(3,260px)}}
@media (min-width:1100px){.model-grid{grid-template-columns:repeat(4,240px)}}

.grid-item{display:block;text-align:center;border-radius:var(--r);overflow:hidden}
.grid-item img{
  width:100%;
  border-radius:var(--r);
  transition:opacity .18s ease;
}
.grid-item:hover img{opacity:.92}
.grid-city{
  font-size:.72rem;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:1.2px;
  display:block;
}
.card-title{
  margin:10px 0 6px;
  font-size:1.05rem;
  font-weight:500;
}

/* Profile */
.profile-header-split{display:flex;gap:44px;align-items:flex-start}
.profile-info{flex:1;min-width:260px}
.profile-hero{flex:1;max-width:520px}
.profile-info h1{
  margin:0 0 10px;
  font-weight:500;
  font-size:2.2rem;
  line-height:1.1;
}

/* City line (quiet) */
.profile-cityline{
  margin:0 0 18px;
  font-size:.78rem;
  text-transform:uppercase;
  letter-spacing:1.3px;
  color:var(--muted);
}
.profile-cityline a{color:inherit}

/* Details grid (stacked) */
.details-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px 22px;
  padding-top:14px;
  border-top:1px solid var(--border);
  margin-top:14px;
}
.detail-label{
  font-size:.72rem;
  text-transform:uppercase;
  letter-spacing:1.3px;
  color:var(--muted);
}
.detail-value{
  margin-top:2px;
  color:var(--fg);
}

/* Contact line (quiet, editorial) */
.contact-line{
  margin-top:18px;
  font-size:.78rem;
  text-transform:uppercase;
  letter-spacing:1.3px;
  color:var(--muted);
}
.contact-line a{color:inherit}
.contact-line a:hover,.contact-line a:focus-visible{color:var(--fg)}
.contact-line .sep{margin:0 10px;color:rgba(10,10,10,0.22)}

/* Images */
.hero-shot,.extra-images img{border-radius:var(--r)}
.extra-images{display:grid;grid-template-columns:1fr 1fr;gap:18px}

/* Footer */
.site-footer{
  border-top:1px solid var(--border);
  color:var(--muted);
  text-align:center;
  font-size:.86rem
}
.footer-nav{
  display:flex;
  gap:16px;
  justify-content:center;
  flex-wrap:wrap;
  margin-bottom:10px
}
.footer-meta{margin:0}

/* Responsive */
@media (max-width:900px){
  .profile-header-split{flex-direction:column}
  .profile-hero{max-width:100%}
  .extra-images{grid-template-columns:1fr}
}
@media (max-width:760px){
  :root{--section:3.2rem}
  .nav{flex-direction:column;align-items:flex-start;gap:14px;padding:34px 0 18px}
  .main-nav{justify-content:flex-start;gap:16px}
  .logo{font-size:1.0rem;letter-spacing:.18rem}
}
@media (max-width:480px){
  .logo{font-size:.98rem}
  .section h1{font-size:1.9rem}
}
