:root{
  --page-width:1100px;
  --accent:#8B7355; /* neutral brownish used in screenshot */
  --bg:#F5F5F0; /* very light beige */
  --text:#111;
}
*{box-sizing:border-box}
html,body{height:100%;}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family: 'Montserrat', system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial;
  -webkit-font-smoothing:antialiased;
}
.site-header{max-width:var(--page-width);margin:0 auto;padding:28px 20px 0;}
.top-nav{display:flex;justify-content:space-between;align-items:center;font-weight:600;color:#222}
.top-nav a{text-decoration:none;color:inherit;font-size:0.85rem}
.top-nav a.right{margin-left:auto}
.masthead{text-align:center;margin-top:22px;margin-bottom:18px}
.brand{
  /* Masthead uses Rubik Bubbles for the distinctive rounded letterforms */
  font-family: 'Rubik Bubbles', 'Montserrat', sans-serif;
  font-weight:700;
  margin:0;
  font-size:96px; /* large to match screenshot */
  line-height:0.85;
  letter-spacing:2px;
  color:#0b0b0b;
}
.tagline{font-size:0.9rem;color:#666;margin-top:8px}
.info-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:18px;margin-top:26px;border-top:1px solid #bfbfbf;padding-top:22px}
.info-box{border:1px solid #bdbdb7;padding:22px;text-align:center;font-weight:600}
.info-box strong{display:block;font-size:1.3rem;margin-top:8px}
.info-box.time{display:flex;flex-direction:column;justify-content:center}

.content{max-width:var(--page-width);margin:36px auto;padding:0 20px 80px}
.gallery{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:140px;gap:18px}

/* position items to match screenshot mosaic proportions */
.g-hero{grid-row:span 3;grid-column:1/2}
.g-hero img{width:100%;height:100%;object-fit:cover;display:block}
.g-small img,.g-thumb img,.g-wide img{width:100%;height:100%;object-fit:cover;display:block}
.g-small{display:flex;align-items:flex-end;position:relative}
.g-small .meta{position:absolute;left:8px;bottom:8px;color:#fff;background:rgba(0,0,0,.5);padding:6px 8px;font-weight:600;font-size:.85rem}
.g-dark{background:#0b0b0b;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600}
.g-cta{background:#fff;border:1px solid #eee;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:1.3rem;color:#000}
.g-cta.big{grid-column:3/4;grid-row:4/6}
.g-thumb{background:#fff}
.g-wide{grid-column:2/4;grid-row:3/4}
.g-dark-sq{background:#111;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600}
.g-black{background:#000}

.about{margin-top:28px;text-align:center;padding:40px 30px 0}
.about p{max-width:760px;margin:0 auto;font-weight:600;color:#222}

/* Enhanced responsiveness for all pages */
@media (max-width:1100px){
  .site-header{padding:20px 16px 0}
  .content{padding:0 16px 60px}
  .brand{font-size:72px}
  .info-row{gap:14px}
  .info-box{padding:16px}
  .info-box strong{font-size:1.1rem}
}

@media (max-width:900px){
  .brand{font-size:60px}
  .gallery{grid-template-columns:repeat(2,1fr);grid-auto-rows:220px;gap:14px}
  .g-hero{grid-row:span 2}
  .g-wide{grid-column:auto;grid-row:auto}
  .info-row{grid-template-columns:repeat(2,1fr);gap:12px}
  
  /* About page tablet adjustments */
  .about-page .about{padding:20px 16px}
  .about-page .grid-2{gap:20px}
  .about-page .values{grid-template-columns:repeat(2,1fr);gap:10px}
  
  /* Contact page tablet adjustments */
  .contact-hero{padding:36px 16px 80px}
  .contact-left{padding:20px 0}
}

@media (max-width:640px){
  .site-header{padding:16px 12px 0}
  .brand{font-size:48px;letter-spacing:1px}
  .tagline{font-size:0.8rem}
  .content{padding:0 12px 40px;margin:24px auto}
  .info-row{grid-template-columns:1fr;gap:10px}
  .gallery{grid-template-columns:1fr;grid-auto-rows:240px;gap:12px}
  .g-hero{grid-row:span 1}
  .g-cta.big{grid-column:auto}
  
  /* About page mobile adjustments */
  .about-page .about{padding:16px 12px}
  .about-page .grid-2{grid-template-columns:1fr;gap:16px}
  .about-page .values{grid-template-columns:1fr;gap:8px}
  .stat h4{font-size:1.4rem}
  
  /* Contact page mobile adjustments */
  .contact-hero{padding:24px 12px 60px}
  .back-home{left:12px;top:16px;font-size:0.9rem}
  .close-x{right:12px;top:14px}
  .contact-container{gap:20px}
  .contact-info li{font-size:0.9rem;margin:8px 0}
  .contact-card{padding:20px 16px}
  .field{padding:12px 14px;font-size:0.9rem}
}

@media (max-width:480px){
  .brand{font-size:40px}
  .gallery{grid-auto-rows:200px}
  .g-small .meta{font-size:0.75rem;padding:4px 6px}
  
  /* Further mobile optimizations */
  .about-page .about h2{font-size:1.75rem}
  .about-page .about h3{font-size:1rem}
  .card{padding:14px}
  .contact-title{font-size:44px}
  .btn-send{padding:14px;font-size:0.9rem}
}

/* small helper styles for images placeholders */
.gallery img{display:block}

/* Note: Replace placeholder images in assets/images with original photos to match precisely. */

/* --- Biography page styles --- */
.biography-page {
  max-width: 1200px;
  padding: 40px 20px;
}

.biography-title {
  font-family: 'Playfair Display', serif;
  font-size: 72px;
  margin-bottom: 60px;
  color: #1a1a1a;
}

.bio-container {
  display: grid;
  grid-template-columns: 380px 1fr;
  gap: 60px;
}

.bio-left {
  display: flex;
  flex-direction: column;
  gap: 40px;
}

.section-title {
  font-size: 0.85rem;
  font-weight: 600;
  color: #666;
  margin-bottom: 20px;
  letter-spacing: 1px;
}

.info-grid {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.info-item {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 12px;
  font-size: 0.95rem;
}

.label {
  color: #666;
  font-weight: 500;
}

.value {
  color: #1a1a1a;
}

.skills-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.skills-list li {
  color: #1a1a1a;
  font-size: 0.95rem;
  position: relative;
  padding-left: 16px;
}

.skills-list li::before {
  content: "•";
  position: absolute;
  left: 0;
  color: #666;
}

.image-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-top: 20px;
}

.bio-img {
  width: 100%;
  aspect-ratio: 3/4;
  object-fit: cover;
  border-radius: 8px;
}

.bio-right {
  padding-top: 20px;
}

.hello-text {
  font-size: 2.5rem;
  color: #1a1a1a;
  margin-bottom: 20px;
}

.bio-text {
  color: #444;
  font-size: 1rem;
  line-height: 1.7;
}

.bio-text p {
  margin-bottom: 20px;
}

/* Biography page responsiveness */
@media (max-width: 1100px) {
  .biography-page {
    padding: 30px 16px;
  }
  .biography-title {
    font-size: 56px;
    margin-bottom: 40px;
  }
  .bio-container {
    gap: 40px;
  }
}

@media (max-width: 900px) {
  .bio-container {
    grid-template-columns: 320px 1fr;
    gap: 30px;
  }
  .biography-title {
    font-size: 48px;
    margin-bottom: 30px;
  }
  .bio-left {
    gap: 30px;
  }
  .hello-text {
    font-size: 2rem;
  }
}

@media (max-width: 768px) {
  .bio-container {
    grid-template-columns: 1fr;
  }
  .bio-left {
    max-width: 500px;
    margin: 0 auto;
  }
  .image-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
  }
  .bio-right {
    padding-top: 0;
  }
  .biography-title {
    text-align: center;
  }
}

@media (max-width: 480px) {
  .biography-page {
    padding: 20px 12px;
  }
  .biography-title {
    font-size: 36px;
    margin-bottom: 24px;
  }
  .info-item {
    font-size: 0.9rem;
  }
  .bio-text {
    font-size: 0.95rem;
  }
  .image-grid {
    grid-template-columns: 1fr;
  }
  .bio-img {
    max-height: 400px;
    width: 100%;
  }
  .hello-text {
    font-size: 1.75rem;
  }
}

.contact-page .about{padding:10px 0}
.contact-wrapper{display:grid;grid-template-columns:1fr 380px;gap:28px;align-items:start}
.contact-form{background:#fff;padding:20px;border-radius:10px;border:1px solid #eee}
.contact-form label{display:block;font-weight:600;margin-bottom:8px;color:#333}
.contact-form input[type=text],.contact-form input[type=email],.contact-form textarea{width:100%;padding:10px;border:1px solid #ddd;border-radius:6px;margin-bottom:12px;font-size:0.95rem}
.contact-form button{background:var(--accent);color:#fff;border:none;padding:12px 18px;border-radius:8px;font-weight:700;cursor:pointer}
.contact-form button:hover{opacity:0.95}
.contact-details{display:flex;flex-direction:column;gap:12px}
.contact-details .info{background:#fff;padding:12px;border-radius:8px;border:1px solid #eee}
.map-frame{width:100%;height:260px;border-radius:8px;border:1px solid #ddd;overflow:hidden}

@media(max-width:900px){
  .about-page .grid-2,.contact-wrapper{grid-template-columns:1fr}
  .about-page .values{grid-template-columns:repeat(2,1fr)}
  .stat{padding:12px}
}

/* Masthead social link */
.social-inline{margin-top:8px}
.social-inline a{display:inline-flex;align-items:center;color:#111;text-decoration:none;font-weight:600}
.social-inline svg{display:inline-block;margin-right:6px}

/* Designer credit shows on scroll */
.designer-credit{
  position:fixed;
  right:15px;
  bottom:10px;
  color:#666;
  text-decoration:none;
  font-size:0.75rem;
  opacity:0;
  transform:translateY(10px);
  transition:opacity 0.3s, transform 0.3s;
}
.designer-credit.visible{
  opacity:1;
  transform:translateY(0);
}
.designer-credit::after{
  content:"❤️";
  display:inline-block;
  margin-left:3px;
  font-size:0.7rem;
}

/* Contact hero (screenshot-inspired) */
.contact-full{min-height:calc(100vh - 80px)}
.contact-hero{background:var(--bg);padding:48px 20px 120px;position:relative}
.contact-container{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 460px;gap:48px;align-items:center}
.back-home{position:absolute;left:20px;top:22px;font-weight:700;text-decoration:none;color:#333}
.close-x{position:absolute;right:20px;top:20px;font-size:20px;text-decoration:none;color:#111;background:transparent;padding:6px 10px;border-radius:8px}
.contact-left{padding:28px 8px}
.eyebrow{font-size:.85rem;color:#7a7a7a;margin:0 0 12px;font-weight:700}
.contact-title{font-family:'Rubik Bubbles','Montserrat',sans-serif;font-size:128px;line-height:0.9;margin:0;color:#0b0b0b}
.contact-info{list-style:none;padding:16px 0 0;margin:18px 0 0;color:#444;font-weight:700}
.contact-info li{margin:10px 0;font-size:0.95rem}

.contact-right{display:flex;align-items:center;justify-content:center}
.contact-card{background:#fff;border-radius:22px;padding:34px;width:100%;max-width:420px;border:2px solid #111;box-shadow:0 30px 60px rgba(0,0,0,0.12)}
.card-title{font-size:0.95rem;letter-spacing:1px;margin:0 0 14px;font-weight:800}
.card-form{display:flex;flex-direction:column;gap:12px}
.field{border:1.6px solid #111;padding:14px 16px;border-radius:28px;font-size:0.95rem;background:transparent}
.field::placeholder{color:#9a9a9a}
.textarea{min-height:120px;padding-top:16px}
.btn-send{margin-top:6px;background:#111;color:#fff;padding:16px;border-radius:28px;border:none;font-weight:800;letter-spacing:1px;box-shadow:0 20px 30px rgba(0,0,0,0.18);cursor:pointer}
.btn-send:hover{transform:translateY(-2px)}

.accessibility-circle{position:fixed;right:20px;bottom:100px;width:56px;height:56px;border-radius:999px;background:#0b5bd7;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;box-shadow:0 18px 40px rgba(11,11,11,0.12)}

@media(max-width:1100px){
  .contact-container{grid-template-columns:1fr 420px;gap:28px}
  .contact-title{font-size:96px}
}
@media(max-width:760px){
  .contact-container{grid-template-columns:1fr;}
  .contact-right{order:2;margin-top:20px}
  .contact-left{order:1}
  .contact-title{font-size:56px}
  .contact-card{border-radius:14px;padding:20px}
  .accessibility-circle{display:none}
}
