/* ===== Dan Brady — danbradycscs.com =====
 * Shared stylesheet
 * =========================================== */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --bg:#FAFAF5;
  --bg2:#F0EFE7;
  --text:#2C2A25;
  --text2:#6B6860;
  --text3:#9A9790;
  --accent:#3B5E4A;
  --accent-light:#4E7A5F;
  --accent-bg:#EDF3EF;
  --warm:#B8875A;
  --warm-bg:#F7F0E8;
  --serif:'Lora',Georgia,serif;
  --sans:'Outfit',system-ui,sans-serif;
  --max:860px;
  --gap:2rem;
}

html{scroll-behavior:smooth}

body{
  font-family:var(--sans);
  color:var(--text);
  background:var(--bg);
  line-height:1.7;
  font-weight:400;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
}

/* ===== Skip link for accessibility ===== */
.skip-link{
  position:absolute;
  left:-9999px;
  top:0;
  background:var(--accent);
  color:#fff;
  padding:.75rem 1.25rem;
  text-decoration:none;
  border-radius:0 0 8px 0;
  font-weight:500;
  z-index:200;
}
.skip-link:focus{left:0}

/* ===== Navigation ===== */
nav{
  position:sticky;
  top:0;
  z-index:100;
  background:rgba(250,250,245,.92);
  backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(0,0,0,.06);
  padding:.85rem var(--gap);
}
nav .inner{
  max-width:var(--max);
  margin:0 auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  flex-wrap:wrap;
}
nav .brand{
  font-family:var(--serif);
  font-weight:600;
  font-size:1.15rem;
  color:var(--accent);
  letter-spacing:-.01em;
  white-space:nowrap;
  text-decoration:none;
}
nav .links{
  display:flex;
  gap:.15rem;
  flex-wrap:wrap;
}
nav .links a{
  font-size:.82rem;
  font-weight:500;
  color:var(--text2);
  padding:.4rem .7rem;
  border-radius:6px;
  transition:all .15s;
  text-decoration:none;
  letter-spacing:.01em;
}
nav .links a:hover{
  color:var(--accent);
  background:var(--accent-bg);
}
nav .links a[aria-current="page"]{
  color:var(--accent);
  background:var(--accent-bg);
}
nav .links a.muted{color:var(--text3)}
nav .links a.muted:hover{color:var(--accent)}

/* ===== Sections ===== */
main{display:block}
section{
  max-width:var(--max);
  margin:0 auto;
  padding:3rem var(--gap);
}
section.hero{
  padding-top:4rem;
  padding-bottom:3rem;
}
.section-break{
  border:0;
  border-top:1px solid rgba(0,0,0,.06);
  max-width:var(--max);
  margin:0 auto;
}

/* ===== Typography ===== */
h1{
  font-family:var(--serif);
  font-size:2.2rem;
  font-weight:600;
  line-height:1.25;
  color:var(--text);
  letter-spacing:-.02em;
  margin-bottom:.6rem;
}
h2{
  font-family:var(--serif);
  font-size:1.55rem;
  font-weight:500;
  line-height:1.3;
  color:var(--text);
  letter-spacing:-.01em;
  margin-bottom:.75rem;
}
h3{
  font-family:var(--serif);
  font-size:1.2rem;
  font-weight:500;
  line-height:1.4;
  color:var(--text);
  margin-bottom:.5rem;
}
p{
  margin-bottom:1rem;
  color:var(--text);
}
p.muted{color:var(--text2)}
p.small{font-size:.9rem}
.lead{
  font-size:1.1rem;
  line-height:1.8;
  color:var(--text2);
}
.hero-sub{
  font-size:1rem;
  line-height:1.7;
  color:var(--text2);
  margin-top:.5rem;
  margin-bottom:.25rem;
}
strong{font-weight:600}
a{color:var(--accent)}

/* ===== Hero layout ===== */
.hero-grid{
  display:grid;
  grid-template-columns:1fr auto;
  gap:3rem;
  align-items:start;
}
.hero-photo{
  width:180px;
  height:180px;
  border-radius:50%;
  object-fit:cover;
  border:3px solid var(--bg2);
  flex-shrink:0;
}
.hero-meta{
  display:flex;
  gap:1rem;
  margin-top:1.5rem;
  flex-wrap:wrap;
  align-items:center;
}
.hero-meta span{
  font-size:.9rem;
  color:var(--text2);
}
.hero-meta .dot{
  width:4px;
  height:4px;
  border-radius:50%;
  background:var(--text3);
  display:inline-block;
}
.hero-meta a{
  font-size:.9rem;
  color:var(--accent);
  text-decoration:none;
  font-weight:500;
  transition:color .15s;
}
.hero-meta a:hover{color:var(--accent-light);text-decoration:underline}

/* ===== Cards ===== */
.card-row{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:1.25rem;
  margin-top:1.5rem;
}
.card{
  background:#fff;
  border:1px solid rgba(0,0,0,.06);
  border-radius:12px;
  padding:1.5rem;
  text-decoration:none;
  color:inherit;
  display:block;
  transition:border-color .15s,transform .15s;
}
.card:hover{
  border-color:var(--accent);
  transform:translateY(-2px);
}
.card h3{margin-bottom:.35rem}
.card p{
  font-size:.9rem;
  color:var(--text2);
  margin-bottom:0;
}
.card .tag{
  display:inline-block;
  font-size:.72rem;
  font-weight:600;
  letter-spacing:.04em;
  text-transform:uppercase;
  padding:.25rem .55rem;
  border-radius:5px;
  margin-bottom:.75rem;
}
.card .tag.green{background:var(--accent-bg);color:var(--accent)}
.card .tag.warm{background:var(--warm-bg);color:var(--warm)}

/* ===== Blockquote ===== */
blockquote{
  border-left:3px solid var(--accent);
  padding-left:1.25rem;
  margin:1.5rem 0;
  font-family:var(--serif);
  font-style:italic;
  color:var(--text2);
  line-height:1.75;
  font-size:1.02rem;
}
blockquote cite{
  display:block;
  font-style:normal;
  font-family:var(--sans);
  font-size:.82rem;
  color:var(--text3);
  margin-top:.5rem;
  font-weight:500;
}

/* ===== Philosophy list ===== */
.phil-list{
  list-style:none;
  margin:1.5rem 0;
}
.phil-list li{
  position:relative;
  padding-left:1.4rem;
  margin-bottom:.75rem;
  font-size:.95rem;
  line-height:1.65;
}
.phil-list li::before{
  content:'';
  position:absolute;
  left:0;
  top:.55rem;
  width:8px;
  height:8px;
  border-radius:50%;
  background:var(--accent-bg);
  border:2px solid var(--accent);
}

/* ===== Credentials ===== */
.cred-section{margin:1.5rem 0}
.cred-section h3{
  font-size:1rem;
  font-weight:600;
  font-family:var(--sans);
  color:var(--text3);
  text-transform:uppercase;
  letter-spacing:.06em;
  margin-bottom:.75rem;
}
.cred-list{list-style:none}
.cred-list li{
  font-size:.9rem;
  padding:.35rem 0;
  color:var(--text2);
}
.cred-list li strong{
  color:var(--text);
  font-weight:500;
}
.role-line{
  display:flex;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:.25rem;
}
.role-line .years{
  color:var(--text3);
  font-size:.82rem;
}

/* ===== CTA block ===== */
.cta-block{
  background:var(--accent-bg);
  border-radius:12px;
  padding:2rem;
  margin-top:2rem;
  text-align:center;
}
.cta-block h3{
  color:var(--accent);
  margin-bottom:.5rem;
}
.cta-block p{
  color:var(--text2);
  margin-bottom:1rem;
  font-size:.95rem;
}
.cta-btn{
  display:inline-block;
  background:var(--accent);
  color:#fff;
  padding:.65rem 1.8rem;
  border-radius:8px;
  font-weight:500;
  font-size:.9rem;
  text-decoration:none;
  transition:background .15s;
  border:0;
}
.cta-btn:hover{background:var(--accent-light)}

/* ===== Client tools card ===== */
.tool-card{
  background:#fff;
  border:1px solid rgba(0,0,0,.06);
  border-radius:12px;
  padding:2rem;
  margin-bottom:1.25rem;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1.5rem;
  flex-wrap:wrap;
}
.tool-card h3{margin-bottom:.25rem}
.tool-card p{
  font-size:.9rem;
  color:var(--text2);
  margin-bottom:0;
}
.tool-link{
  display:inline-block;
  background:var(--accent);
  color:#fff;
  padding:.5rem 1.25rem;
  border-radius:8px;
  font-weight:500;
  font-size:.85rem;
  text-decoration:none;
  white-space:nowrap;
  transition:background .15s;
}
.tool-link:hover{background:var(--accent-light)}

/* ===== Footer ===== */
footer{
  border-top:1px solid rgba(0,0,0,.06);
  padding:2rem var(--gap);
  margin-top:2rem;
}
footer .inner{
  max-width:var(--max);
  margin:0 auto;
}
footer .footer-links{
  display:flex;
  gap:1.25rem;
  flex-wrap:wrap;
  margin-bottom:.75rem;
}
footer .footer-links a{
  font-size:.85rem;
  color:var(--text2);
  text-decoration:none;
  transition:color .15s;
}
footer .footer-links a:hover{color:var(--accent)}
footer p{
  font-size:.82rem;
  color:var(--text3);
  margin-bottom:.35rem;
}
footer a{
  color:var(--text2);
  text-decoration:none;
}
footer a:hover{color:var(--accent)}
footer .copyright{
  font-size:.78rem;
  color:var(--text3);
  margin-top:.5rem;
}

/* ===== Audience segments ===== */
.segment{margin-bottom:2.5rem}
.segment:last-child{margin-bottom:0}

/* ===== 404 page ===== */
.not-found{
  text-align:center;
  padding:5rem var(--gap);
  max-width:var(--max);
  margin:0 auto;
}
.not-found h1{
  font-size:3rem;
  margin-bottom:1rem;
}

/* ===== Responsive ===== */
@media(max-width:640px){
  .hero-grid{
    grid-template-columns:1fr;
    text-align:center;
  }
  .hero-photo{margin:0 auto 1rem}
  h1{font-size:1.75rem}
  .hero-meta{justify-content:center}
  nav .inner{justify-content:center}
  nav .links{justify-content:center}
  .tool-card{
    flex-direction:column;
    align-items:flex-start;
  }
}

/* ===== Print ===== */
@media print{
  nav,footer,.cta-block{display:none}
  body{background:#fff;color:#000}
  a{color:#000;text-decoration:underline}
}
