  body { font-family: Arial, sans-serif; margin: 0; padding: 12px; }
  label { color: #006633; display:block; font-weight:bold; margin-top:8px; }
  select { width: 90%; min-height: 50px; margin-bottom: 6px; }
  button { padding: 6px 10px; margin-top:8px; }
  .panel { min-height: 100vh; display: flex; gap: 20px;}
  .left { margin-left: 20px; width: 240px; padding-right: 10px; }
  .vline { width: 3px;   background: #1e40af;   border: none;   margin: 0 30px;   height: 100vh; }
  .right { flex: 1; }
  .block { margin-bottom: 28px; }
  .header { margin-left: 40px; font-weight: bold; margin-top: 20px; margin-bottom: 20px; display:flex; align-items:center; gap:6px; font-size: 22px; }
  .info { cursor:pointer; font-weight:bold; border:2px solid black; border-radius:50%; width:30px; height:30px; display:inline-flex; align-items:center; justify-content:center; font-size:20px; background:#fff; }
  #inv { height: 75px; }
  #fam { height: 140px; }
  #spp { height: 140px; }
  #str { height: 80px; }
  #view { height: 90px; }
/* ===== SPPINFO VIEWER ===== */
  .sppinfo-box {position: fixed; top: 120px; left: 50%; transform: translateX(-50%); background: #fff; border-radius: 6px;  box-shadow: 0 8px 24px rgba(0,0,0,0.35);  width: 420px;  z-index: 800px;  font-size: 15px; }
  .sppinfo-header { display: flex; justify-content: flex-end; padding: 6px 8px;}
  .sppinfo-close { cursor: pointer; font-size: 14px; border: 1px solid #999; border-radius: 3px; padding: 0 6px; background: #f5f5f5;}
  .sppinfo-body { padding: 10px 14px 14px 14px; line-height: 1.4;}
  .sppinfo-body div { margin-bottom: 4px;}
  .sppinfo-body b { font-weight: bold;}
  .section { margin-bottom: 10px; }
  .section-title { margin-left: 40px; font-weight: normal; margin-bottom: 10px; font-size: 19px; margin-top: 20px}
  .grid { margin-left: 40px; display: flex; flex-wrap: wrap; gap: 8px; }
  .card { display:flex; flex-direction:column; align-items:center; max-width:280px; }
  .card img { max-width: 280px; height: auto; border: 1px solid #ccc; background:#f7f7f7; cursor:zoom-in; }
  .caption { font-size: 14px; text-align:center; margin-top:2px; }
  .msg { margin-top:10px; color:#900; white-space:pre-wrap; }
  .overlay { position: fixed; inset: 0; background: rgba(255,255,255,0.9); display: flex; align-items: center; justify-content: center; z-index: 9999;}
  .render-overlay-box {border: 2px solid #1e40af; padding: 20px 28px; font-size: 18px; background: #fff; color: #000; max-width: 420px; text-align: center;}
  .render-overlay {position: absolute; inset: 0; background: rgba(255,255,255,0.9); display: flex; align-items: flex-start; justify-content: center; z-index: 50; padding-top: 300px; /* desplazamiento hacia abajo */}
  .render-render-overlay-box {border: 2px solid #1e40af; padding: 20px 28px; font-size: 18px; background: #fff; color: #000; max-width: 420px; text-align: center;}
/* --- Fixed left panel, scrollable right panel (replicate online behavior) --- */
  .panel {height: 100vh;}
  .left {position: fixed; top: 0; left: 0; width: 240px; height: 100vh; overflow-y: auto;}
  .vline {position: fixed; top: 0; left: 240px; height: 100vh;}
  .right {margin-left: 260px; /* left width + line gap */ height: 100vh; overflow-y: auto;}
  /* === Allow multiline text in select menus === */
  select option {white-space: normal; word-break: break-word; line-height: 1.2; padding-left: 15px;text-indent: -10px; }
