/* =========================================================
   Persona, clean rebuild
   Works with: <section id="persona" class="persona is-compact">
   No HTML changes needed
========================================================= */

/* tokens */
:root{
  --ink-900:#FFCCCC;
  --ink-700:#FFCCCC;
  --ink-600:#FFCCCC;
  --panel:#f4f6f8;
  --card:#ffffff;
  --line:oklab(65.824% 0.18078 0.08193);

  /* brand accents used lightly */
  --blue:#FFCCCC !important;

  --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 */
#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;
  gap: clamp(14px, 2vw, 20px);
  align-items: start;
}

/* profile card */
#persona .persona-profile{
background: linear-gradient(180deg, #ffffff 0%, #f7c9d0 35%, #d31334 70%, #b30f28 100%);
  border: 1px solid rgba(255, 255, 255, 0.55);
  border-radius: var(--r-lg);
  padding: 12px;
  box-shadow: var(--shadow-sm);
  color: #ffffff;
}
#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: #ffffff; }

/* body column */
#persona .persona-body{ 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; }

/* quote strip */
#persona .quote{
  margin: 4px 0 0;
  border:1px solid #d31334;
  color:black;
  background-color: white;
  border-radius: var(--r-md);
  padding: clamp(10px, 1.2vw, 14px) clamp(12px, 1.6vw, 18px);
  box-shadow: var(--shadow-sm);
}
#persona .quote blockquote{
  margin:0;
  font-size: clamp(13.5px, 1.3vw, 15px);
  line-height: 1.5;
  font-style: italic;
}

/* compact variant with masonry columns, avoids empty holes */
#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,
#persona.persona.is-compact .quote{
  -webkit-column-span: all;
  column-span: all;
}

/* responsive */
@media (max-width: 980px){
  #persona .persona-rail{
    grid-template-columns: 1fr;
  }
  #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, keeps layout tidy if photo is missing */
#persona .profile-photo.is-missing{
  display:grid; place-items:center;
  min-height: 220px;
  background: repeating-linear-gradient(
    45deg,
    rgba(191, 27, 27, 0.9) 0 8px,
    rgba(255,255,255,.6) 8px 16px
  );
  color:#344054;
  border: 1px dashed #FFCCCC;
  font-size: 12px;
}
