/*
Theme Name: John Wilkinson Site
Theme URI: https://johnwilkinsondenver.com
Author: Threshold Agency
Description: Custom one-page WordPress theme for John Wilkinson.
Version: 1.0.0
*/

.credential-list li::before {
  content: '✦';
}

.door-link::after {
  content: '→';
}

    /* Reset & base */
    *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
    html { scroll-behavior: smooth; }
    body {
      font-family: 'Georgia', 'Times New Roman', serif;
      background: #ffffff;
      color: #1a1a2e;
      line-height: 1.7;
    }
    a { text-decoration: none; color: inherit; }
    img { max-width: 100%; display: block; }

    /* Typography scale */
    .sans { font-family: -apple-system, 'Helvetica Neue', Arial, sans-serif; }

    /* Nav */
    nav {
      background: #1a1a2e;
      padding: 16px 5%;
      display: flex;
      align-items: center;
      justify-content: space-between;
    }
    .nav-name {
      font-family: -apple-system, 'Helvetica Neue', Arial, sans-serif;
      font-size: 15px;
      font-weight: 600;
      color: #ffffff;
      letter-spacing: 0.04em;
      text-transform: uppercase;
    }
    .nav-links {
      display: flex;
      gap: 28px;
      list-style: none;
    }
    .nav-links a {
      font-family: -apple-system, 'Helvetica Neue', Arial, sans-serif;
      font-size: 13px;
      color: rgba(255,255,255,0.75);
      letter-spacing: 0.03em;
      transition: color 0.2s;
    }
    .nav-links a:hover { color: #e54b4b; }

    /* Hero */
    .hero {
      background: #1a1a2e;
      padding: 80px 5% 70px;
      display: grid;
      grid-template-columns: 1fr auto;
      gap: 48px;
      align-items: center;
      max-width: 1100px;
      margin: 0 auto;
    }
    .hero-eyebrow {
      font-family: -apple-system, 'Helvetica Neue', Arial, sans-serif;
      font-size: 11px;
      font-weight: 700;
      letter-spacing: 0.18em;
      text-transform: uppercase;
      color: #e54b4b;
      margin-bottom: 16px;
    }
    .hero h1 {
      font-size: clamp(36px, 5vw, 56px);
      font-weight: 400;
      color: #ffffff;
      line-height: 1.15;
      margin-bottom: 20px;
    }
    .hero h1 em {
      font-style: normal;
      color: #e54b4b;
    }
    .hero-sub {
      font-family: -apple-system, 'Helvetica Neue', Arial, sans-serif;
      font-size: 17px;
      color: rgba(255,255,255,0.72);
      max-width: 540px;
      line-height: 1.6;
      margin-bottom: 32px;
    }
    .hero-cta {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      background: #e54b4b;
      color: #ffffff;
      font-family: -apple-system, 'Helvetica Neue', Arial, sans-serif;
      font-size: 14px;
      font-weight: 600;
      letter-spacing: 0.04em;
      padding: 14px 28px;
      border-radius: 4px;
      transition: background 0.2s, transform 0.15s;
    }
    .hero-cta:hover { background: #c03838; transform: translateY(-1px); }
.hero-photo {
  width: 220px;
  height: 220px;
  border-radius: 8px;
  object-fit: cover;
  border: 4px solid rgba(229,75,75,0.5);
  flex-shrink: 0;
}

    /* Stats bar */
    .stats-bar {
      background: #e54b4b;
      padding: 0;
    }
    .stats-inner {
      max-width: 1100px;
      margin: 0 auto;
      display: grid;
      grid-template-columns: repeat(4, 1fr);
    }
    .stat {
      padding: 28px 24px;
      border-right: 1px solid rgba(255,255,255,0.2);
      text-align: center;
    }
    .stat:last-child { border-right: none; }
    .stat-num {
      font-size: 36px;
      font-weight: 400;
      color: #ffffff;
      line-height: 1;
      margin-bottom: 6px;
    }
    .stat-label {
      font-family: -apple-system, 'Helvetica Neue', Arial, sans-serif;
      font-size: 11px;
      font-weight: 600;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      color: rgba(255,255,255,0.82);
    }

    /* Section wrapper */
    .section {
      max-width: 1100px;
      margin: 0 auto;
      padding: 72px 5%;
    }
    .section-label {
      font-family: -apple-system, 'Helvetica Neue', Arial, sans-serif;
      font-size: 11px;
      font-weight: 700;
      letter-spacing: 0.18em;
      text-transform: uppercase;
      color: #e54b4b;
      margin-bottom: 14px;
    }
    .section h2 {
      font-size: clamp(26px, 3.5vw, 36px);
      font-weight: 400;
      color: #1a1a2e;
      margin-bottom: 24px;
      line-height: 1.25;
    }

    /* Story / bio */
    .story-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 56px;
      align-items: start;
    }
    .story-body p {
      font-size: 17px;
      color: #3a3a5e;
      line-height: 1.8;
      margin-bottom: 20px;
    }
    .story-body p:last-child { margin-bottom: 0; }
    .story-aside {
      background: #f5f5fc;
      border-left: 4px solid #e54b4b;
      padding: 32px 28px;
      border-radius: 0 8px 8px 0;
    }
    .story-aside h3 {
      font-family: -apple-system, 'Helvetica Neue', Arial, sans-serif;
      font-size: 13px;
      font-weight: 700;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      color: #e54b4b;
      margin-bottom: 20px;
    }
    .credential-list {
      list-style: disc;
  padding-left: 1.2rem;
    }
    .credential-list li {
      font-family: -apple-system, 'Helvetica Neue', Arial, sans-serif;
      font-size: 14px;
      color: #1a1a2e;
    display: list-item;
  padding: 9px 0;
  border-bottom: 1px solid rgba(26,26,46,0.08);
  line-height: 1.4;

    }
    .credential-list li:last-child { border-bottom: none; }
    .credential-list li::before {
     content: none;
    }

    /* Divider */
    .divider {
      border: none;
      border-top: 1px solid rgba(26,26,46,0.1);
      margin: 0 5%;
    }

    /* Three doors */
    .doors-section {
      background: #1a1a2e;
      padding: 72px 5%;
    }
    .doors-inner {
      max-width: 1100px;
      margin: 0 auto;
    }
    .doors-label {
      font-family: -apple-system, 'Helvetica Neue', Arial, sans-serif;
      font-size: 11px;
      font-weight: 700;
      letter-spacing: 0.18em;
      text-transform: uppercase;
      color: #e54b4b;
      margin-bottom: 14px;
    }
    .doors-headline {
      font-size: clamp(24px, 3vw, 34px);
      font-weight: 400;
      color: #ffffff;
      margin-bottom: 48px;
      line-height: 1.3;
    }
    .doors-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 24px;
    }
    .door {
      background: rgba(255,255,255,0.05);
      border: 1px solid rgba(255,255,255,0.1);
      border-radius: 8px;
      padding: 36px 32px;
      transition: background 0.2s, border-color 0.2s, transform 0.2s;
      display: flex;
      flex-direction: column;
    }
    .door:hover {
      background: rgba(229,75,75,0.12);
      border-color: rgba(229,75,75,0.5);
      transform: translateY(-3px);
    }
    .door-icon {
      font-size: 32px;
      margin-bottom: 18px;
    }
    .door-tag {
      font-family: -apple-system, 'Helvetica Neue', Arial, sans-serif;
      font-size: 10px;
      font-weight: 700;
      letter-spacing: 0.16em;
      text-transform: uppercase;
      color: #e54b4b;
      margin-bottom: 10px;
    }
    .door h3 {
      font-size: 20px;
      font-weight: 400;
      color: #ffffff;
      margin-bottom: 14px;
      line-height: 1.25;
    }
    .door p {
      font-family: -apple-system, 'Helvetica Neue', Arial, sans-serif;
      font-size: 14px;
      color: rgba(255,255,255,0.65);
      line-height: 1.65;
      flex-grow: 1;
      margin-bottom: 28px;
    }
    .door-link {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      font-family: -apple-system, 'Helvetica Neue', Arial, sans-serif;
      font-size: 13px;
      font-weight: 600;
      letter-spacing: 0.04em;
      color: #e54b4b;
      transition: gap 0.2s;
    }
    .door:hover .door-link { gap: 10px; }
    .door-link::after {
  content: "\2192";
}

    /* Connect */
    .connect-section {
      padding: 72px 5%;
      background: #f5f5fc;
    }
    .connect-inner {
      max-width: 680px;
      margin: 0 auto;
      text-align: center;
    }
    .connect-inner .section-label { text-align: center; }
    .connect-inner h2 { margin-bottom: 14px; }
    .connect-inner p {
      font-family: -apple-system, 'Helvetica Neue', Arial, sans-serif;
      font-size: 16px;
      color: #5a5a7e;
      margin-bottom: 36px;
    }
    .connect-buttons {
      display: flex;
      gap: 16px;
      justify-content: center;
      flex-wrap: wrap;
    }
    .btn-primary {
      background: #1a1a2e;
      color: #ffffff;
      font-family: -apple-system, 'Helvetica Neue', Arial, sans-serif;
      font-size: 14px;
      font-weight: 600;
      letter-spacing: 0.04em;
      padding: 14px 28px;
      border-radius: 4px;
      transition: background 0.2s;
    }
    .btn-primary:hover { background: #e54b4b; }
    .btn-secondary {
      background: transparent;
      color: #1a1a2e;
      font-family: -apple-system, 'Helvetica Neue', Arial, sans-serif;
      font-size: 14px;
      font-weight: 600;
      letter-spacing: 0.04em;
      padding: 13px 28px;
      border-radius: 4px;
      border: 2px solid #1a1a2e;
      transition: border-color 0.2s, color 0.2s;
    }
    .btn-secondary:hover { border-color: #e54b4b; color: #e54b4b; }

    /* Footer */
    footer {
      background: #1a1a2e;
      padding: 32px 5%;
      display: flex;
      align-items: center;
      justify-content: space-between;
      flex-wrap: wrap;
      gap: 16px;
    }
    .footer-name {
      font-family: -apple-system, 'Helvetica Neue', Arial, sans-serif;
      font-size: 14px;
      font-weight: 600;
      color: #ffffff;
    }
    .footer-links {
      display: flex;
      gap: 24px;
      list-style: none;
      flex-wrap: wrap;
    }
    .footer-links a {
      font-family: -apple-system, 'Helvetica Neue', Arial, sans-serif;
      font-size: 13px;
      color: rgba(255,255,255,0.55);
      transition: color 0.2s;
    }
    .footer-links a:hover { color: #e54b4b; }

    /*  Responsive  */
    @media (max-width: 800px) {
      .hero {
        grid-template-columns: 1fr;
        text-align: center;
        padding: 56px 5% 52px;
      }
      .hero-photo {
        width: 160px;
        height: 160px;
        margin: 0 auto;
        order: -1;
      }
      .hero-sub { margin: 0 auto 28px; }
      .stats-inner {
        grid-template-columns: repeat(2, 1fr);
      }
      .stat { border-right: none; border-bottom: 1px solid rgba(255,255,255,0.15); }
      .stat:nth-child(2n) { }
      .stat:nth-last-child(-n+2) { border-bottom: none; }
      .story-grid { grid-template-columns: 1fr; gap: 36px; }
      .doors-grid { grid-template-columns: 1fr; }
      .nav-links { display: none; }
    }
    @media (max-width: 480px) {
      .stats-inner { grid-template-columns: 1fr 1fr; }
      .stat-num { font-size: 28px; }
    }