:root{
  --ink:#000;
  --bg:#F3F2EC;
  --text:#222;
  --muted:#333;
  --teal:#00B7C2;
  --tan:#D69F6A;
  --maroon:#9B1D3A;
  --burg:#581C1C;
  --beige:#F6E0CC;
  --card-shadow-offset: 10px;
}

/* Base */
*{box-sizing:border-box}
body{
  margin:0;
  font-family:'Archivo',system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial;
  background:var(--bg);
  color:var(--text);
  line-height:1.5;
}

/* NAV */
nav{
  position:sticky;top:0;z-index:10;
  background:#fff;border-bottom:4px solid var(--ink);
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 24px;
}
.brand{font-weight:600}
nav a{color:#000;text-decoration:none;font-weight:400;letter-spacing:.4px;padding:.45rem .8rem;transition:color .2s, transform .2s}
nav a:hover{color:var(--teal);transform:translate(-2px,-2px)}

/* WRAP */
.wrap{max-width:1200px;margin:0 auto;padding:24px 24px 56px 24px}

/* HERO */
.hero{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center}
.hero h1{font-size:clamp(36px,5vw,56px);font-weight:400;letter-spacing:-.02em;line-height:1.1}
.hero p{margin-top:12px;font-size:18px;color:var(--muted);max-width:56ch}
.cta{margin-top:24px;display:flex;gap:14px}
.btn{
  text-decoration:none;display:inline-block;padding:10px 22px;
  border:3px solid var(--ink);background:var(--tan);color:#fff;font-weight:500;
  box-shadow:6px 6px 0 var(--burg);transition:transform .2s, box-shadow .2s
}
.btn:hover{transform:translate(-3px,-3px);box-shadow:9px 9px 0 var(--teal)}

.hero-art{display:grid;place-items:center}
.hero-art img{width:clamp(200px,40vw,380px);height:auto;max-width:100%}

/* SECTIONS */
section{padding:72px 0}
.section-title{font-size:32px;font-weight:400;margin-bottom:12px}
.rule{height:4px;width:120px;background:var(--ink);margin:6px 0 28px}

/* PROJECT GRID */
.grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:36px}

/* Reusable card */
.card{
  background:#fff;
  border:3px solid var(--ink);
  box-shadow: var(--card-shadow-offset) var(--card-shadow-offset) 0 var(--tan);
  transition:transform .3s, box-shadow .3s;
}
.card:nth-child(2){box-shadow: var(--card-shadow-offset) var(--card-shadow-offset) 0 var(--burg)}
.card:nth-child(3){box-shadow: var(--card-shadow-offset) var(--card-shadow-offset) 0 var(--maroon)}

.grid .card:hover {
  transform:translate(-6px,-6px);
  box-shadow: calc(var(--card-shadow-offset) + 4px) calc(var(--card-shadow-offset) + 4px) 0 var(--teal);
}
.grid .card:nth-child(2):hover {
  box-shadow: calc(var(--card-shadow-offset) + 4px) calc(var(--card-shadow-offset) + 4px) 0 var(--maroon);
}


.ph{height:180px;display:grid;place-items:center;border-bottom:3px solid var(--ink);color:#777}
.card .body{padding:16px}
.card h3{font-weight:500;margin:0 0 8px}

/* ABOUT + CONTACT */
.about-alt{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:clamp(20px,4vw,40px);
  align-items:start;
}

/* About card */
.bio-card{
  --card-shadow-color: var(--teal);
  padding:clamp(14px,2.2vw,22px);
  box-shadow: var(--card-shadow-offset) var(--card-shadow-offset) 0 var(--card-shadow-color);
}

/* Contact panel */
.contact-panel{
  --card-shadow-color: var(--maroon);
  padding:clamp(14px,2.2vw,22px);
  box-shadow: var(--card-shadow-offset) var(--card-shadow-offset) 0 var(--card-shadow-color);
}

.bio-top{display:flex;gap:16px;align-items:center;margin-bottom:14px}
.bio-pic{width:68px;height:68px;border:3px solid var(--ink);border-radius:9999px;background:linear-gradient(135deg,#F8E9D9,#E6F7F8)}
.bio-name{font-size:clamp(18px,2.2vw,20px);font-weight:600;margin:0}
.badges{display:flex;flex-wrap:wrap;gap:clamp(6px,1vw,8px);margin:10px 0 4px}
.badge{
  border:2px solid var(--ink);padding:4px 8px;line-height:1;border-radius:999px;background:#fff;
  font-size:clamp(12px,1.6vw,14px);
  transition:background-color .2s,color .2s,transform .2s;
}
.badge:hover{background:var(--tan);color:#fff;transform:translate(-2px,-2px)}
.bio-card p{margin:8px 0;color:var(--muted)}
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:clamp(8px,1.4vw,12px);margin:14px 0}
.stat{border:2px solid var(--ink);background:#fff;padding:clamp(8px,1.5vw,10px);text-align:center}
.stat b{display:block;font-size:clamp(16px,2.4vw,18px)}

.contact-panel h3{margin:0 0 8px;font-size:clamp(18px,2.2vw,22px)}
.contact-item{margin:10px 0}
.contact-panel a:not(.btn-link){color:var(--maroon);text-decoration:underline}
.contact-panel a:not(.btn-link):hover{color:var(--teal);background:none}

.contact-panel .btn-link{
  display:inline-block;margin-top:10px;border:3px solid var(--ink);padding:10px 16px;
  box-shadow:6px 6px 0 var(--burg);text-decoration:none;background:var(--tan);color:#fff;font-weight:600;
  transition:transform .2s, box-shadow .2s;
}
.contact-panel .btn-link:hover{transform:translate(-2px,-2px);box-shadow:8px 8px 0 var(--teal)}

/* FOOTER */
.skyline-svg,
.skyline{
  width:100%;
  max-width:none;
  height:auto;
  display:block;
  margin:0 auto 8px;
  color:#313131;
}
.skyline-svg path[stroke]{fill:none;stroke-width:4;stroke-linecap:round;stroke-linejoin:round}
.copy{text-align:center;opacity:.9;margin-top:36px;margin-bottom:24px}

/* Reveal-on-scroll */
[data-animate]{opacity:0;transform:translateY(20px);transition:opacity .8s, transform .8s}
[data-animate].visible{opacity:1;transform:translateY(0)}

/* ---------- RESPONSIVE ---------- */

/* <=1080 */
@media (max-width:1080px){
  .about-alt{grid-template-columns:1fr .9fr}
}

/* <=960 */
@media (max-width:960px){
  .hero{grid-template-columns:1fr .9fr}
  .hero-art {
  display: flex;
  justify-content: center;}
  .hero-art img {  margin: 0 auto; width:clamp(200px,40vw,380px)}
  .shape{display:none}
  .grid{grid-template-columns:1fr}
  .about-alt{grid-template-columns:1fr}
  .contact-panel{order:-1}
}

/* <=768 */
@media (max-width:768px){
  section {
    padding: 32px 0; /* or even 32px if you want it tighter */
  }
  .wrap{padding:32px 20px}
  nav{padding:10px 14px;border-bottom-width:3px}
  nav a{font-size:15px;padding:.3rem .4rem}
  nav a:hover{transform:translate(-1px,-1px)}
  .hero{grid-template-columns:1fr}
  .hero p{font-size:16px}
  .hero-art {display:none}
  .grid{gap:24px}
  .ph{height:150px}
  .section-title{font-size:26px}
  .rule{width:88px;height:3px}
  .bio-pic{width:56px;height:56px}
  .stats{gap:8px}
}

/* <=650 */
@media (max-width:650px){
  .hero{grid-template-columns:1fr}
  .hero-art{display:none}
  .about-alt{gap:20px}
  .stats{grid-template-columns:repeat(2,1fr)}
  .btn-link{width:100%;text-align:center}
}

/* <=550 */
@media (max-width:550px){
  .bio-top {
    flex-direction: column;
    align-items: flex-start; /* or center if you want it centered */
    gap: 10px;
  }
  .hero{grid-template-columns:1fr}
  .about-alt{gap:20px}
  .stats{grid-template-columns:repeat(2,1fr)}
  .btn-link{width:100%;text-align:center}
}

/* <=380 */
@media (max-width:380px){
  .bio-top {
    flex-direction: column;
    align-items: flex-start; /* or center if you want it centered */
    gap: 10px;
  }
  nav a{font-size:14px}
  .hero h1{font-size:clamp(24px,7.5vw,32px)}
  .hero-art img{width:clamp(50px,72vw,250px)}
  .btn{padding:10px 14px;box-shadow:5px 5px 0 var(--burg)}
}

/* Reduced motion */
@media (prefers-reduced-motion:reduce){
  .btn, .btn-link{transition:none}
}

/* 404 page */
.not-found {
  min-height: 60vh;
  display: grid;
  place-items: center;
  text-align: center;
  gap: 0.75rem;
  padding: 6rem 0.5rem 4rem;
  margin-bottom: 3rem
}

.not-found h1 {
  font-size: clamp(4rem, 12vw, 10rem);
  line-height: 0.9;
  letter-spacing: -0.02em;
  color: var(--ink);
  margin: 0;
}

.not-found .lead {
  font-size: clamp(1.1rem, 2.2vw, 1.5rem);
  color: var(--muted);
  margin: 0.25rem 0 0rem;
}


.not-found .cta {
  display: flex;
  gap: 0.75rem;
  justify-content: center;
  flex-wrap: wrap;
  margin-top: 0rem;
}

/* ensure footer stays full-bleed here too */
footer { width: 100%; }
.skyline-svg { display:block; width:100%; height:auto; }
