/* =========================================================
   Persona, clean rebuild with quote under profile,
   grid alignment fixed
========================================================= */

/* tokens */
:root{
  --ink-900:#111827;
  --ink-700:#374151;
  --ink-600:#4b5563;
  --panel:#f4f6f8;
  --card:#ffffff;
  --line:#e5e7eb;

  /* brand accents used lightly */
  --blue:#165C7D;
  --coral:#FF6C63;
  --gold:#F2B134;

  --r-lg:14px;
  --r-md:12px;
  --r-sm:10px;

  --shadow-sm:0 6px 16px rgba(2,12,27,.08);
  --shadow-md:0 14px 32px rgba(2,12,27,.10);
}

/* section wrapper */
#persona.persona{
  padding: clamp(20px, 3vw, 32px) 0;
  color: var(--ink-900);
  font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

/* rail grid */
#persona .persona-rail{
  max-width: 1120px;
  margin: 0 auto;
  padding: 0 clamp(16px, 3vw, 28px);
  display: grid;
  grid-template-columns: clamp(240px, 26vw, 300px) 1fr;
  grid-auto-rows: auto;
  gap: clamp(14px, 2vw, 20px);
  align-items: start;
}

/* profile card in left col, row 1 */
#persona .persona-profile{
  grid-column: 1;
  grid-row: 1;
  background: linear-gradient(180deg, #fbe6b6 0%, #f7cf74 65%, #f2b134 100%);
  border: 1px solid rgba(255,255,255,.55);
  border-radius: var(--r-lg);
  padding: 12px;
  box-shadow: var(--shadow-sm);
  color: #1f232b;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
#persona .profile-photo{
  border-radius: var(--r-md);
  overflow: hidden;
  background: rgba(255,255,255,.55);
}
#persona .profile-photo img{
  width:100%; height:auto; display:block; object-fit:cover;
}
#persona .profile-name{
  margin: 10px 4px 8px;
  font-size: clamp(18px, 1.6vw, 20px);
  font-weight: 800;
  letter-spacing:.2px;
}
#persona .profile-facts{
  list-style:none; margin:0; padding:0;
  display:grid; gap:6px;
  font-size: 13.5px;
}
#persona .profile-facts li strong{ color:#0d1320; }

/* quote directly under profile, left col, row 2 */
#persona .quote{
  grid-column: 1;
  grid-row: 2;
  margin-top: 12px;
  background: none;
  border: none;
  padding: 0;
  box-shadow: none;
}
#persona .quote blockquote{
  margin: 0;
  font-size: 14px;
  line-height: 1.5;
  font-style: italic;
  color: var(--ink-900);
  position: relative;
  padding-left: 12px;
}
#persona .quote blockquote::before{
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  width: 3px;
  background: var(--blue);
  border-radius: 2px;
}

/* persona body stays in right col, aligned to top */
#persona .persona-body{
  grid-column: 2;
  grid-row: 1 / span 2; /* spans same rows as profile+quote */
  display:grid;
  gap: clamp(10px, 1.2vw, 14px);
}

/* title */
#persona .persona-title h2{
  margin:0;
  font-size: clamp(18px, 2vw, 22px);
  font-weight: 800;
  color: var(--ink-700);
  line-height: 1.25;
  padding-bottom: 8px;
  border-bottom: 2px solid #d8dee6;
}

/* tile grid default */
#persona .tiles{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: clamp(12px, 1.4vw, 16px);
}

/* card base */
#persona .tile{
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: clamp(12px, 1.4vw, 16px);
  box-shadow: var(--shadow-sm);
  transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}
#persona .tile:hover{
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
  border-color: #d9dee6;
}

/* headings and text */
#persona .tile h4{
  margin:0 0 8px;
  font-size: clamp(14px, 1.4vw, 16px);
  font-weight: 800;
  color:#0f1626;
}
#persona .tile p{
  margin:0;
  font-size: 14px;
  line-height: 1.6;
  color: var(--ink-900);
}

/* lists with dot markers */
#persona .tile ul{
  margin:0; padding:0;
  display:grid; gap: 6px;
  list-style:none;
  font-size: 14px;
  line-height: 1.55;
}
#persona .tile ul li{
  position:relative;
  padding-left:14px;
}
#persona .tile ul li::before{
  content:"";
  position:absolute; left:0; top:.68em;
  width:8px; height:8px; border-radius:50%;
  background: #9aa4b2;
  box-shadow: inset 0 0 0 2px #fff;
}

/* make Bio full width for breathing room */
#persona .tile.bio{ grid-column: 1 / -1; }

/* Behaviors spans full to balance the layout on larger screens */
#persona .tile.behavior{ grid-column: 1 / -1; }

/* compact variant with masonry columns */
#persona.persona.is-compact .tiles{
  display:block;
  column-count: 2;
  column-gap: clamp(12px, 1.4vw, 16px);
}
#persona.persona.is-compact .tile{
  display:block;
  width:100%;
  margin:0 0 clamp(12px, 1.4vw, 16px);
  break-inside: avoid;
}
#persona.persona.is-compact .tile.bio,
#persona.persona.is-compact .tile.behavior{
  -webkit-column-span: all;
  column-span: all;
}

/* responsive */
@media (max-width: 980px){
  #persona .persona-rail{
    grid-template-columns: 1fr;
  }
  #persona .persona-profile{
    grid-column: 1;
    grid-row: auto;
  }
  #persona .quote{
    grid-column: 1;
    grid-row: auto;
  }
  #persona .persona-body{
    grid-column: 1;
    grid-row: auto;
  }
  #persona .tiles{
    grid-template-columns: 1fr;
  }
  #persona.persona.is-compact .tiles{
    column-count: 1;
    column-gap: 0;
  }
}

@media (max-width: 620px){
  #persona .persona-profile{
    text-align:center;
  }
  #persona .profile-photo{ max-width: 220px; margin: 0 auto 10px; }
}

/* image fallback */
#persona .profile-photo.is-missing{
  display:grid; place-items:center;
  min-height: 220px;
  background: repeating-linear-gradient(
    45deg,
    rgba(255,255,255,.9) 0 8px,
    rgba(255,255,255,.6) 8px 16px
  );
  color:#344054;
  border: 1px dashed #cbd5e1;
  font-size: 12px;
}
